diff --git a/.gitattributes b/.gitattributes
new file mode 100644
index 0000000..31eeee0
--- /dev/null
+++ b/.gitattributes
@@ -0,0 +1,7 @@
+# See https://git-scm.com/docs/gitattributes for more about git attribute files.
+
+# Mark the database schema as having been generated.
+db/schema.rb linguist-generated
+
+# Mark any vendored files as having been vendored.
+vendor/* linguist-vendored
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..886f714
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,35 @@
+# See https://help.github.com/articles/ignoring-files for more about ignoring files.
+#
+# If you find yourself ignoring temporary files generated by your text editor
+# or operating system, you probably want to add a global ignore instead:
+# git config --global core.excludesfile '~/.gitignore_global'
+
+# Ignore bundler config.
+/.bundle
+
+# Ignore the default SQLite database.
+/db/*.sqlite3
+/db/*.sqlite3-*
+
+# Ignore all logfiles and tempfiles.
+/log/*
+/tmp/*
+!/log/.keep
+!/tmp/.keep
+
+# Ignore pidfiles, but keep the directory.
+/tmp/pids/*
+!/tmp/pids/
+!/tmp/pids/.keep
+
+# Ignore uploaded files in development.
+/storage/*
+!/storage/.keep
+/tmp/storage/*
+!/tmp/storage/
+!/tmp/storage/.keep
+
+/public/assets
+
+# Ignore master key for decrypting credentials and more.
+/config/master.key
diff --git a/.ruby-version b/.ruby-version
new file mode 100644
index 0000000..79bc2c7
--- /dev/null
+++ b/.ruby-version
@@ -0,0 +1 @@
+ruby-3.0.4
diff --git a/Banner.png b/Banner.png
deleted file mode 100644
index 32299c5..0000000
Binary files a/Banner.png and /dev/null differ
diff --git a/Gemfile b/Gemfile
new file mode 100644
index 0000000..70bcb79
--- /dev/null
+++ b/Gemfile
@@ -0,0 +1,72 @@
+source "https://rubygems.org"
+git_source(:github) { |repo| "https://github.com/#{repo}.git" }
+
+ruby "3.0.4"
+
+# Bundle edge Rails instead: gem "rails", github: "rails/rails", branch: "main"
+gem "rails", "~> 7.0.2", ">= 7.0.2.4"
+
+# The original asset pipeline for Rails [https://github.com/rails/sprockets-rails]
+gem "sprockets-rails"
+
+# Use sqlite3 as the database for Active Record
+gem "sqlite3", "~> 1.4"
+
+# Use the Puma web server [https://github.com/puma/puma]
+gem "puma", "~> 5.0"
+
+# Use JavaScript with ESM import maps [https://github.com/rails/importmap-rails]
+gem "importmap-rails"
+
+# Hotwire's SPA-like page accelerator [https://turbo.hotwired.dev]
+gem "turbo-rails"
+
+# Hotwire's modest JavaScript framework [https://stimulus.hotwired.dev]
+gem "stimulus-rails"
+
+# Build JSON APIs with ease [https://github.com/rails/jbuilder]
+gem "jbuilder"
+
+# Use Redis adapter to run Action Cable in production
+# gem "redis", "~> 4.0"
+
+# Use Kredis to get higher-level data types in Redis [https://github.com/rails/kredis]
+# gem "kredis"
+
+# Use Active Model has_secure_password [https://guides.rubyonrails.org/active_model_basics.html#securepassword]
+# gem "bcrypt", "~> 3.1.7"
+
+# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
+gem "tzinfo-data", platforms: %i[ mingw mswin x64_mingw jruby ]
+
+# Reduces boot times through caching; required in config/boot.rb
+gem "bootsnap", require: false
+
+# Use Sass to process CSS
+# gem "sassc-rails"
+
+# Use Active Storage variants [https://guides.rubyonrails.org/active_storage_overview.html#transforming-images]
+# gem "image_processing", "~> 1.2"
+
+group :development, :test do
+ # See https://guides.rubyonrails.org/debugging_rails_applications.html#debugging-with-the-debug-gem
+ gem "debug", platforms: %i[ mri mingw x64_mingw ]
+end
+
+group :development do
+ # Use console on exceptions pages [https://github.com/rails/web-console]
+ gem "web-console"
+
+ # Add speed badges [https://github.com/MiniProfiler/rack-mini-profiler]
+ # gem "rack-mini-profiler"
+
+ # Speed up commands on slow machines / big apps [https://github.com/rails/spring]
+ # gem "spring"
+end
+
+group :test do
+ # Use system testing [https://guides.rubyonrails.org/testing.html#system-testing]
+ gem "capybara"
+ gem "selenium-webdriver"
+ gem "webdrivers"
+end
diff --git a/Gemfile.lock b/Gemfile.lock
new file mode 100644
index 0000000..474fb87
--- /dev/null
+++ b/Gemfile.lock
@@ -0,0 +1,234 @@
+GEM
+ remote: https://rubygems.org/
+ specs:
+ actioncable (7.0.2.4)
+ actionpack (= 7.0.2.4)
+ activesupport (= 7.0.2.4)
+ nio4r (~> 2.0)
+ websocket-driver (>= 0.6.1)
+ actionmailbox (7.0.2.4)
+ actionpack (= 7.0.2.4)
+ activejob (= 7.0.2.4)
+ activerecord (= 7.0.2.4)
+ activestorage (= 7.0.2.4)
+ activesupport (= 7.0.2.4)
+ mail (>= 2.7.1)
+ net-imap
+ net-pop
+ net-smtp
+ actionmailer (7.0.2.4)
+ actionpack (= 7.0.2.4)
+ actionview (= 7.0.2.4)
+ activejob (= 7.0.2.4)
+ activesupport (= 7.0.2.4)
+ mail (~> 2.5, >= 2.5.4)
+ net-imap
+ net-pop
+ net-smtp
+ rails-dom-testing (~> 2.0)
+ actionpack (7.0.2.4)
+ actionview (= 7.0.2.4)
+ activesupport (= 7.0.2.4)
+ rack (~> 2.0, >= 2.2.0)
+ rack-test (>= 0.6.3)
+ rails-dom-testing (~> 2.0)
+ rails-html-sanitizer (~> 1.0, >= 1.2.0)
+ actiontext (7.0.2.4)
+ actionpack (= 7.0.2.4)
+ activerecord (= 7.0.2.4)
+ activestorage (= 7.0.2.4)
+ activesupport (= 7.0.2.4)
+ globalid (>= 0.6.0)
+ nokogiri (>= 1.8.5)
+ actionview (7.0.2.4)
+ activesupport (= 7.0.2.4)
+ builder (~> 3.1)
+ erubi (~> 1.4)
+ rails-dom-testing (~> 2.0)
+ rails-html-sanitizer (~> 1.1, >= 1.2.0)
+ activejob (7.0.2.4)
+ activesupport (= 7.0.2.4)
+ globalid (>= 0.3.6)
+ activemodel (7.0.2.4)
+ activesupport (= 7.0.2.4)
+ activerecord (7.0.2.4)
+ activemodel (= 7.0.2.4)
+ activesupport (= 7.0.2.4)
+ activestorage (7.0.2.4)
+ actionpack (= 7.0.2.4)
+ activejob (= 7.0.2.4)
+ activerecord (= 7.0.2.4)
+ activesupport (= 7.0.2.4)
+ marcel (~> 1.0)
+ mini_mime (>= 1.1.0)
+ activesupport (7.0.2.4)
+ concurrent-ruby (~> 1.0, >= 1.0.2)
+ i18n (>= 1.6, < 2)
+ minitest (>= 5.1)
+ tzinfo (~> 2.0)
+ addressable (2.8.0)
+ public_suffix (>= 2.0.2, < 5.0)
+ bindex (0.8.1)
+ bootsnap (1.11.1)
+ msgpack (~> 1.2)
+ builder (3.2.4)
+ capybara (3.37.0)
+ addressable
+ matrix
+ mini_mime (>= 0.1.3)
+ nokogiri (~> 1.8)
+ rack (>= 1.6.0)
+ rack-test (>= 0.6.3)
+ regexp_parser (>= 1.5, < 3.0)
+ xpath (~> 3.2)
+ childprocess (4.1.0)
+ concurrent-ruby (1.1.10)
+ crass (1.0.6)
+ debug (1.5.0)
+ irb (>= 1.3.6)
+ reline (>= 0.2.7)
+ digest (3.1.0)
+ erubi (1.10.0)
+ globalid (1.0.0)
+ activesupport (>= 5.0)
+ i18n (1.10.0)
+ concurrent-ruby (~> 1.0)
+ importmap-rails (1.0.3)
+ actionpack (>= 6.0.0)
+ railties (>= 6.0.0)
+ io-console (0.5.11)
+ irb (1.4.1)
+ reline (>= 0.3.0)
+ jbuilder (2.11.5)
+ actionview (>= 5.0.0)
+ activesupport (>= 5.0.0)
+ loofah (2.17.0)
+ crass (~> 1.0.2)
+ nokogiri (>= 1.5.9)
+ mail (2.7.1)
+ mini_mime (>= 0.1.1)
+ marcel (1.0.2)
+ matrix (0.4.2)
+ method_source (1.0.0)
+ mini_mime (1.1.2)
+ minitest (5.15.0)
+ msgpack (1.5.1)
+ net-imap (0.2.3)
+ digest
+ net-protocol
+ strscan
+ net-pop (0.1.1)
+ digest
+ net-protocol
+ timeout
+ net-protocol (0.1.3)
+ timeout
+ net-smtp (0.3.1)
+ digest
+ net-protocol
+ timeout
+ nio4r (2.5.8)
+ nokogiri (1.13.6-x86_64-linux)
+ racc (~> 1.4)
+ public_suffix (4.0.7)
+ puma (5.6.4)
+ nio4r (~> 2.0)
+ racc (1.6.0)
+ rack (2.2.3)
+ rack-test (1.1.0)
+ rack (>= 1.0, < 3)
+ rails (7.0.2.4)
+ actioncable (= 7.0.2.4)
+ actionmailbox (= 7.0.2.4)
+ actionmailer (= 7.0.2.4)
+ actionpack (= 7.0.2.4)
+ actiontext (= 7.0.2.4)
+ actionview (= 7.0.2.4)
+ activejob (= 7.0.2.4)
+ activemodel (= 7.0.2.4)
+ activerecord (= 7.0.2.4)
+ activestorage (= 7.0.2.4)
+ activesupport (= 7.0.2.4)
+ bundler (>= 1.15.0)
+ railties (= 7.0.2.4)
+ rails-dom-testing (2.0.3)
+ activesupport (>= 4.2.0)
+ nokogiri (>= 1.6)
+ rails-html-sanitizer (1.4.2)
+ loofah (~> 2.3)
+ railties (7.0.2.4)
+ actionpack (= 7.0.2.4)
+ activesupport (= 7.0.2.4)
+ method_source
+ rake (>= 12.2)
+ thor (~> 1.0)
+ zeitwerk (~> 2.5)
+ rake (13.0.6)
+ regexp_parser (2.3.1)
+ reline (0.3.1)
+ io-console (~> 0.5)
+ rexml (3.2.5)
+ rubyzip (2.3.2)
+ selenium-webdriver (4.1.0)
+ childprocess (>= 0.5, < 5.0)
+ rexml (~> 3.2, >= 3.2.5)
+ rubyzip (>= 1.2.2)
+ sprockets (4.0.3)
+ concurrent-ruby (~> 1.0)
+ rack (> 1, < 3)
+ sprockets-rails (3.4.2)
+ actionpack (>= 5.2)
+ activesupport (>= 5.2)
+ sprockets (>= 3.0.0)
+ sqlite3 (1.4.2)
+ stimulus-rails (1.0.4)
+ railties (>= 6.0.0)
+ strscan (3.0.1)
+ thor (1.2.1)
+ timeout (0.2.0)
+ turbo-rails (1.0.1)
+ actionpack (>= 6.0.0)
+ railties (>= 6.0.0)
+ tzinfo (2.0.4)
+ concurrent-ruby (~> 1.0)
+ web-console (4.2.0)
+ actionview (>= 6.0.0)
+ activemodel (>= 6.0.0)
+ bindex (>= 0.4.0)
+ railties (>= 6.0.0)
+ webdrivers (5.0.0)
+ nokogiri (~> 1.6)
+ rubyzip (>= 1.3.0)
+ selenium-webdriver (~> 4.0)
+ websocket-driver (0.7.5)
+ websocket-extensions (>= 0.1.0)
+ websocket-extensions (0.1.5)
+ xpath (3.2.0)
+ nokogiri (~> 1.8)
+ zeitwerk (2.5.4)
+
+PLATFORMS
+ x86_64-linux
+
+DEPENDENCIES
+ bootsnap
+ capybara
+ debug
+ importmap-rails
+ jbuilder
+ puma (~> 5.0)
+ rails (~> 7.0.2, >= 7.0.2.4)
+ selenium-webdriver
+ sprockets-rails
+ sqlite3 (~> 1.4)
+ stimulus-rails
+ turbo-rails
+ tzinfo-data
+ web-console
+ webdrivers
+
+RUBY VERSION
+ ruby 3.0.4p208
+
+BUNDLED WITH
+ 2.3.13
diff --git a/README.md b/README.md
index c206937..7db80e4 100644
--- a/README.md
+++ b/README.md
@@ -1,3 +1,24 @@
-# Portfolio
-My portfolio website!
-
+# README
+
+This README would normally document whatever steps are necessary to get the
+application up and running.
+
+Things you may want to cover:
+
+* Ruby version
+
+* System dependencies
+
+* Configuration
+
+* Database creation
+
+* Database initialization
+
+* How to run the test suite
+
+* Services (job queues, cache servers, search engines, etc.)
+
+* Deployment instructions
+
+* ...
diff --git a/Rakefile b/Rakefile
new file mode 100644
index 0000000..9a5ea73
--- /dev/null
+++ b/Rakefile
@@ -0,0 +1,6 @@
+# Add your own tasks in files placed in lib/tasks ending in .rake,
+# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
+
+require_relative "config/application"
+
+Rails.application.load_tasks
diff --git a/app/assets/config/manifest.js b/app/assets/config/manifest.js
new file mode 100644
index 0000000..ddd546a
--- /dev/null
+++ b/app/assets/config/manifest.js
@@ -0,0 +1,4 @@
+//= link_tree ../images
+//= link_directory ../stylesheets .css
+//= link_tree ../../javascript .js
+//= link_tree ../../../vendor/javascript .js
diff --git a/python/assignments/4.3.html b/app/assets/images/.keep
similarity index 100%
rename from python/assignments/4.3.html
rename to app/assets/images/.keep
diff --git a/app/assets/stylesheets/application.css b/app/assets/stylesheets/application.css
new file mode 100644
index 0000000..288b9ab
--- /dev/null
+++ b/app/assets/stylesheets/application.css
@@ -0,0 +1,15 @@
+/*
+ * This is a manifest file that'll be compiled into application.css, which will include all the files
+ * listed below.
+ *
+ * Any CSS (and SCSS, if configured) file within this directory, lib/assets/stylesheets, or any plugin's
+ * vendor/assets/stylesheets directory can be referenced here using a relative path.
+ *
+ * You're free to add application-wide styles to this file and they'll appear at the bottom of the
+ * compiled file so the styles you add here take precedence over styles defined in any other CSS
+ * files in this directory. Styles in this file should be added after the last require_* statement.
+ * It is generally better to create a new file per style scope.
+ *
+ *= require_tree .
+ *= require_self
+ */
diff --git a/app/channels/application_cable/channel.rb b/app/channels/application_cable/channel.rb
new file mode 100644
index 0000000..d672697
--- /dev/null
+++ b/app/channels/application_cable/channel.rb
@@ -0,0 +1,4 @@
+module ApplicationCable
+ class Channel < ActionCable::Channel::Base
+ end
+end
diff --git a/app/channels/application_cable/connection.rb b/app/channels/application_cable/connection.rb
new file mode 100644
index 0000000..0ff5442
--- /dev/null
+++ b/app/channels/application_cable/connection.rb
@@ -0,0 +1,4 @@
+module ApplicationCable
+ class Connection < ActionCable::Connection::Base
+ end
+end
diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb
new file mode 100644
index 0000000..09705d1
--- /dev/null
+++ b/app/controllers/application_controller.rb
@@ -0,0 +1,2 @@
+class ApplicationController < ActionController::Base
+end
diff --git a/python/editor.js b/app/controllers/concerns/.keep
similarity index 100%
rename from python/editor.js
rename to app/controllers/concerns/.keep
diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb
new file mode 100644
index 0000000..de6be79
--- /dev/null
+++ b/app/helpers/application_helper.rb
@@ -0,0 +1,2 @@
+module ApplicationHelper
+end
diff --git a/app/javascript/application.js b/app/javascript/application.js
new file mode 100644
index 0000000..0d7b494
--- /dev/null
+++ b/app/javascript/application.js
@@ -0,0 +1,3 @@
+// Configure your import map in config/importmap.rb. Read more: https://github.com/rails/importmap-rails
+import "@hotwired/turbo-rails"
+import "controllers"
diff --git a/app/javascript/controllers/application.js b/app/javascript/controllers/application.js
new file mode 100644
index 0000000..1213e85
--- /dev/null
+++ b/app/javascript/controllers/application.js
@@ -0,0 +1,9 @@
+import { Application } from "@hotwired/stimulus"
+
+const application = Application.start()
+
+// Configure Stimulus development experience
+application.debug = false
+window.Stimulus = application
+
+export { application }
diff --git a/app/javascript/controllers/hello_controller.js b/app/javascript/controllers/hello_controller.js
new file mode 100644
index 0000000..5975c07
--- /dev/null
+++ b/app/javascript/controllers/hello_controller.js
@@ -0,0 +1,7 @@
+import { Controller } from "@hotwired/stimulus"
+
+export default class extends Controller {
+ connect() {
+ this.element.textContent = "Hello World!"
+ }
+}
diff --git a/app/javascript/controllers/index.js b/app/javascript/controllers/index.js
new file mode 100644
index 0000000..54ad4ca
--- /dev/null
+++ b/app/javascript/controllers/index.js
@@ -0,0 +1,11 @@
+// Import and register all your controllers from the importmap under controllers/*
+
+import { application } from "controllers/application"
+
+// Eager load all controllers defined in the import map under controllers/**/*_controller
+import { eagerLoadControllersFrom } from "@hotwired/stimulus-loading"
+eagerLoadControllersFrom("controllers", application)
+
+// Lazy load controllers as they appear in the DOM (remember not to preload controllers in import map!)
+// import { lazyLoadControllersFrom } from "@hotwired/stimulus-loading"
+// lazyLoadControllersFrom("controllers", application)
diff --git a/app/jobs/application_job.rb b/app/jobs/application_job.rb
new file mode 100644
index 0000000..d394c3d
--- /dev/null
+++ b/app/jobs/application_job.rb
@@ -0,0 +1,7 @@
+class ApplicationJob < ActiveJob::Base
+ # Automatically retry jobs that encountered a deadlock
+ # retry_on ActiveRecord::Deadlocked
+
+ # Most jobs are safe to ignore if the underlying records are no longer available
+ # discard_on ActiveJob::DeserializationError
+end
diff --git a/app/mailers/application_mailer.rb b/app/mailers/application_mailer.rb
new file mode 100644
index 0000000..3c34c81
--- /dev/null
+++ b/app/mailers/application_mailer.rb
@@ -0,0 +1,4 @@
+class ApplicationMailer < ActionMailer::Base
+ default from: "from@example.com"
+ layout "mailer"
+end
diff --git a/app/models/application_record.rb b/app/models/application_record.rb
new file mode 100644
index 0000000..b63caeb
--- /dev/null
+++ b/app/models/application_record.rb
@@ -0,0 +1,3 @@
+class ApplicationRecord < ActiveRecord::Base
+ primary_abstract_class
+end
diff --git a/app/models/concerns/.keep b/app/models/concerns/.keep
new file mode 100644
index 0000000..e69de29
diff --git a/app/views/layouts/application.html.erb b/app/views/layouts/application.html.erb
new file mode 100644
index 0000000..1917378
--- /dev/null
+++ b/app/views/layouts/application.html.erb
@@ -0,0 +1,16 @@
+
+
+
+ Site
+
+ <%= csrf_meta_tags %>
+ <%= csp_meta_tag %>
+
+ <%= stylesheet_link_tag "application", "data-turbo-track": "reload" %>
+ <%= javascript_importmap_tags %>
+
+
+
+ <%= yield %>
+
+
diff --git a/app/views/layouts/mailer.html.erb b/app/views/layouts/mailer.html.erb
new file mode 100644
index 0000000..cbd34d2
--- /dev/null
+++ b/app/views/layouts/mailer.html.erb
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+ <%= yield %>
+
+
diff --git a/app/views/layouts/mailer.text.erb b/app/views/layouts/mailer.text.erb
new file mode 100644
index 0000000..37f0bdd
--- /dev/null
+++ b/app/views/layouts/mailer.text.erb
@@ -0,0 +1 @@
+<%= yield %>
diff --git a/assignments.html b/assignments.html
deleted file mode 100644
index b11e3a3..0000000
--- a/assignments.html
+++ /dev/null
@@ -1,88 +0,0 @@
-
-
-
- Assignments
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/bin/bundle b/bin/bundle
new file mode 100755
index 0000000..981e650
--- /dev/null
+++ b/bin/bundle
@@ -0,0 +1,114 @@
+#!/usr/bin/env ruby
+# frozen_string_literal: true
+
+#
+# This file was generated by Bundler.
+#
+# The application 'bundle' is installed as part of a gem, and
+# this file is here to facilitate running it.
+#
+
+require "rubygems"
+
+m = Module.new do
+ module_function
+
+ def invoked_as_script?
+ File.expand_path($0) == File.expand_path(__FILE__)
+ end
+
+ def env_var_version
+ ENV["BUNDLER_VERSION"]
+ end
+
+ def cli_arg_version
+ return unless invoked_as_script? # don't want to hijack other binstubs
+ return unless "update".start_with?(ARGV.first || " ") # must be running `bundle update`
+ bundler_version = nil
+ update_index = nil
+ ARGV.each_with_index do |a, i|
+ if update_index && update_index.succ == i && a =~ Gem::Version::ANCHORED_VERSION_PATTERN
+ bundler_version = a
+ end
+ next unless a =~ /\A--bundler(?:[= ](#{Gem::Version::VERSION_PATTERN}))?\z/
+ bundler_version = $1
+ update_index = i
+ end
+ bundler_version
+ end
+
+ def gemfile
+ gemfile = ENV["BUNDLE_GEMFILE"]
+ return gemfile if gemfile && !gemfile.empty?
+
+ File.expand_path("../Gemfile", __dir__)
+ end
+
+ def lockfile
+ lockfile =
+ case File.basename(gemfile)
+ when "gems.rb" then gemfile.sub(/\.rb$/, gemfile)
+ else "#{gemfile}.lock"
+ end
+ File.expand_path(lockfile)
+ end
+
+ def lockfile_version
+ return unless File.file?(lockfile)
+ lockfile_contents = File.read(lockfile)
+ return unless lockfile_contents =~ /\n\nBUNDLED WITH\n\s{2,}(#{Gem::Version::VERSION_PATTERN})\n/
+ Regexp.last_match(1)
+ end
+
+ def bundler_requirement
+ @bundler_requirement ||=
+ env_var_version || cli_arg_version ||
+ bundler_requirement_for(lockfile_version)
+ end
+
+ def bundler_requirement_for(version)
+ return "#{Gem::Requirement.default}.a" unless version
+
+ bundler_gem_version = Gem::Version.new(version)
+
+ requirement = bundler_gem_version.approximate_recommendation
+
+ return requirement unless Gem.rubygems_version < Gem::Version.new("2.7.0")
+
+ requirement += ".a" if bundler_gem_version.prerelease?
+
+ requirement
+ end
+
+ def load_bundler!
+ ENV["BUNDLE_GEMFILE"] ||= gemfile
+
+ activate_bundler
+ end
+
+ def activate_bundler
+ gem_error = activation_error_handling do
+ gem "bundler", bundler_requirement
+ end
+ return if gem_error.nil?
+ require_error = activation_error_handling do
+ require "bundler/version"
+ end
+ return if require_error.nil? && Gem::Requirement.new(bundler_requirement).satisfied_by?(Gem::Version.new(Bundler::VERSION))
+ warn "Activating bundler (#{bundler_requirement}) failed:\n#{gem_error.message}\n\nTo install the version of bundler this project requires, run `gem install bundler -v '#{bundler_requirement}'`"
+ exit 42
+ end
+
+ def activation_error_handling
+ yield
+ nil
+ rescue StandardError, LoadError => e
+ e
+ end
+end
+
+m.load_bundler!
+
+if m.invoked_as_script?
+ load Gem.bin_path("bundler", "bundle")
+end
diff --git a/bin/importmap b/bin/importmap
new file mode 100755
index 0000000..36502ab
--- /dev/null
+++ b/bin/importmap
@@ -0,0 +1,4 @@
+#!/usr/bin/env ruby
+
+require_relative "../config/application"
+require "importmap/commands"
diff --git a/bin/rails b/bin/rails
new file mode 100755
index 0000000..efc0377
--- /dev/null
+++ b/bin/rails
@@ -0,0 +1,4 @@
+#!/usr/bin/env ruby
+APP_PATH = File.expand_path("../config/application", __dir__)
+require_relative "../config/boot"
+require "rails/commands"
diff --git a/bin/rake b/bin/rake
new file mode 100755
index 0000000..4fbf10b
--- /dev/null
+++ b/bin/rake
@@ -0,0 +1,4 @@
+#!/usr/bin/env ruby
+require_relative "../config/boot"
+require "rake"
+Rake.application.run
diff --git a/bin/setup b/bin/setup
new file mode 100755
index 0000000..ec47b79
--- /dev/null
+++ b/bin/setup
@@ -0,0 +1,33 @@
+#!/usr/bin/env ruby
+require "fileutils"
+
+# path to your application root.
+APP_ROOT = File.expand_path("..", __dir__)
+
+def system!(*args)
+ system(*args) || abort("\n== Command #{args} failed ==")
+end
+
+FileUtils.chdir APP_ROOT do
+ # This script is a way to set up or update your development environment automatically.
+ # This script is idempotent, so that you can run it at any time and get an expectable outcome.
+ # Add necessary setup steps to this file.
+
+ puts "== Installing dependencies =="
+ system! "gem install bundler --conservative"
+ system("bundle check") || system!("bundle install")
+
+ # puts "\n== Copying sample files =="
+ # unless File.exist?("config/database.yml")
+ # FileUtils.cp "config/database.yml.sample", "config/database.yml"
+ # end
+
+ puts "\n== Preparing database =="
+ system! "bin/rails db:prepare"
+
+ puts "\n== Removing old logs and tempfiles =="
+ system! "bin/rails log:clear tmp:clear"
+
+ puts "\n== Restarting application server =="
+ system! "bin/rails restart"
+end
diff --git a/blog.html b/blog.html
deleted file mode 100644
index a58f8fc..0000000
--- a/blog.html
+++ /dev/null
@@ -1,92 +0,0 @@
-
-
-
- Blog
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
Work In Progress
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/config.ru b/config.ru
new file mode 100644
index 0000000..4a3c09a
--- /dev/null
+++ b/config.ru
@@ -0,0 +1,6 @@
+# This file is used by Rack-based servers to start the application.
+
+require_relative "config/environment"
+
+run Rails.application
+Rails.application.load_server
diff --git a/config/application.rb b/config/application.rb
new file mode 100644
index 0000000..e05cb3e
--- /dev/null
+++ b/config/application.rb
@@ -0,0 +1,22 @@
+require_relative "boot"
+
+require "rails/all"
+
+# Require the gems listed in Gemfile, including any gems
+# you've limited to :test, :development, or :production.
+Bundler.require(*Rails.groups)
+
+module Site
+ class Application < Rails::Application
+ # Initialize configuration defaults for originally generated Rails version.
+ config.load_defaults 7.0
+
+ # Configuration for the application, engines, and railties goes here.
+ #
+ # These settings can be overridden in specific environments using the files
+ # in config/environments, which are processed later.
+ #
+ # config.time_zone = "Central Time (US & Canada)"
+ # config.eager_load_paths << Rails.root.join("extras")
+ end
+end
diff --git a/config/boot.rb b/config/boot.rb
new file mode 100644
index 0000000..988a5dd
--- /dev/null
+++ b/config/boot.rb
@@ -0,0 +1,4 @@
+ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../Gemfile", __dir__)
+
+require "bundler/setup" # Set up gems listed in the Gemfile.
+require "bootsnap/setup" # Speed up boot time by caching expensive operations.
diff --git a/config/cable.yml b/config/cable.yml
new file mode 100644
index 0000000..4b49f63
--- /dev/null
+++ b/config/cable.yml
@@ -0,0 +1,10 @@
+development:
+ adapter: async
+
+test:
+ adapter: test
+
+production:
+ adapter: redis
+ url: <%= ENV.fetch("REDIS_URL") { "redis://localhost:6379/1" } %>
+ channel_prefix: site_production
diff --git a/config/credentials.yml.enc b/config/credentials.yml.enc
new file mode 100644
index 0000000..35e9f69
--- /dev/null
+++ b/config/credentials.yml.enc
@@ -0,0 +1 @@
+XM0Cfn0mGEehkF7BAjbqk6WKgSmJN415e7bSTDOlIimlmcuqAF9Op2Mk90rX8TQTBJ5pFrD9oGr8ZunGAEdKvqHaCo3MOQ6E4S0cov54ZjT4/4BczTk6QXFtZxw/rLtDz81JefcEEYjF5SexCQPVwN32R0azWo+guyxXmQPeaMY9PG9CMER77SNmRWq3PI4dJRcGlufb02e670/yeiHjG2IkwS1BcRL0xZXtjWYYot4E1IdqhWrnq3T4LJpnWF+41vGZfG61MpwqQevE63lJwmWeO+ziiSdCz5TRjZf5Lc08cTygzJ+vpkjoOS0byoS9rBRnREybu4hSALi4X9ZhY5bA5veiXhIHurUXkxOrPGftOg7RCT1o4gCetF6oEm8O79NLVNl5/sm7b8RztihSNudhAcT6c5IRpFAJ--SS8r5XNP/wB71jM2--s6JBAPa1mCsaZTkasH35xQ==
\ No newline at end of file
diff --git a/config/database.yml b/config/database.yml
new file mode 100644
index 0000000..fcba57f
--- /dev/null
+++ b/config/database.yml
@@ -0,0 +1,25 @@
+# SQLite. Versions 3.8.0 and up are supported.
+# gem install sqlite3
+#
+# Ensure the SQLite 3 gem is defined in your Gemfile
+# gem "sqlite3"
+#
+default: &default
+ adapter: sqlite3
+ pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
+ timeout: 5000
+
+development:
+ <<: *default
+ database: db/development.sqlite3
+
+# Warning: The database defined as "test" will be erased and
+# re-generated from your development database when you run "rake".
+# Do not set this db to the same as development or production.
+test:
+ <<: *default
+ database: db/test.sqlite3
+
+production:
+ <<: *default
+ database: db/production.sqlite3
diff --git a/config/environment.rb b/config/environment.rb
new file mode 100644
index 0000000..cac5315
--- /dev/null
+++ b/config/environment.rb
@@ -0,0 +1,5 @@
+# Load the Rails application.
+require_relative "application"
+
+# Initialize the Rails application.
+Rails.application.initialize!
diff --git a/config/environments/development.rb b/config/environments/development.rb
new file mode 100644
index 0000000..8500f45
--- /dev/null
+++ b/config/environments/development.rb
@@ -0,0 +1,70 @@
+require "active_support/core_ext/integer/time"
+
+Rails.application.configure do
+ # Settings specified here will take precedence over those in config/application.rb.
+
+ # In the development environment your application's code is reloaded any time
+ # it changes. This slows down response time but is perfect for development
+ # since you don't have to restart the web server when you make code changes.
+ config.cache_classes = false
+
+ # Do not eager load code on boot.
+ config.eager_load = false
+
+ # Show full error reports.
+ config.consider_all_requests_local = true
+
+ # Enable server timing
+ config.server_timing = true
+
+ # Enable/disable caching. By default caching is disabled.
+ # Run rails dev:cache to toggle caching.
+ if Rails.root.join("tmp/caching-dev.txt").exist?
+ config.action_controller.perform_caching = true
+ config.action_controller.enable_fragment_cache_logging = true
+
+ config.cache_store = :memory_store
+ config.public_file_server.headers = {
+ "Cache-Control" => "public, max-age=#{2.days.to_i}"
+ }
+ else
+ config.action_controller.perform_caching = false
+
+ config.cache_store = :null_store
+ end
+
+ # Store uploaded files on the local file system (see config/storage.yml for options).
+ config.active_storage.service = :local
+
+ # Don't care if the mailer can't send.
+ config.action_mailer.raise_delivery_errors = false
+
+ config.action_mailer.perform_caching = false
+
+ # Print deprecation notices to the Rails logger.
+ config.active_support.deprecation = :log
+
+ # Raise exceptions for disallowed deprecations.
+ config.active_support.disallowed_deprecation = :raise
+
+ # Tell Active Support which deprecation messages to disallow.
+ config.active_support.disallowed_deprecation_warnings = []
+
+ # Raise an error on page load if there are pending migrations.
+ config.active_record.migration_error = :page_load
+
+ # Highlight code that triggered database queries in logs.
+ config.active_record.verbose_query_logs = true
+
+ # Suppress logger output for asset requests.
+ config.assets.quiet = true
+
+ # Raises error for missing translations.
+ # config.i18n.raise_on_missing_translations = true
+
+ # Annotate rendered view with file names.
+ # config.action_view.annotate_rendered_view_with_filenames = true
+
+ # Uncomment if you wish to allow Action Cable access from any origin.
+ # config.action_cable.disable_request_forgery_protection = true
+end
diff --git a/config/environments/production.rb b/config/environments/production.rb
new file mode 100644
index 0000000..7392098
--- /dev/null
+++ b/config/environments/production.rb
@@ -0,0 +1,93 @@
+require "active_support/core_ext/integer/time"
+
+Rails.application.configure do
+ # Settings specified here will take precedence over those in config/application.rb.
+
+ # Code is not reloaded between requests.
+ config.cache_classes = true
+
+ # Eager load code on boot. This eager loads most of Rails and
+ # your application in memory, allowing both threaded web servers
+ # and those relying on copy on write to perform better.
+ # Rake tasks automatically ignore this option for performance.
+ config.eager_load = true
+
+ # Full error reports are disabled and caching is turned on.
+ config.consider_all_requests_local = false
+ config.action_controller.perform_caching = true
+
+ # Ensures that a master key has been made available in either ENV["RAILS_MASTER_KEY"]
+ # or in config/master.key. This key is used to decrypt credentials (and other encrypted files).
+ # config.require_master_key = true
+
+ # Disable serving static files from the `/public` folder by default since
+ # Apache or NGINX already handles this.
+ config.public_file_server.enabled = ENV["RAILS_SERVE_STATIC_FILES"].present?
+
+ # Compress CSS using a preprocessor.
+ # config.assets.css_compressor = :sass
+
+ # Do not fallback to assets pipeline if a precompiled asset is missed.
+ config.assets.compile = false
+
+ # Enable serving of images, stylesheets, and JavaScripts from an asset server.
+ # config.asset_host = "http://assets.example.com"
+
+ # Specifies the header that your server uses for sending files.
+ # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for Apache
+ # config.action_dispatch.x_sendfile_header = "X-Accel-Redirect" # for NGINX
+
+ # Store uploaded files on the local file system (see config/storage.yml for options).
+ config.active_storage.service = :local
+
+ # Mount Action Cable outside main process or domain.
+ # config.action_cable.mount_path = nil
+ # config.action_cable.url = "wss://example.com/cable"
+ # config.action_cable.allowed_request_origins = [ "http://example.com", /http:\/\/example.*/ ]
+
+ # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
+ # config.force_ssl = true
+
+ # Include generic and useful information about system operation, but avoid logging too much
+ # information to avoid inadvertent exposure of personally identifiable information (PII).
+ config.log_level = :info
+
+ # Prepend all log lines with the following tags.
+ config.log_tags = [ :request_id ]
+
+ # Use a different cache store in production.
+ # config.cache_store = :mem_cache_store
+
+ # Use a real queuing backend for Active Job (and separate queues per environment).
+ # config.active_job.queue_adapter = :resque
+ # config.active_job.queue_name_prefix = "site_production"
+
+ config.action_mailer.perform_caching = false
+
+ # Ignore bad email addresses and do not raise email delivery errors.
+ # Set this to true and configure the email server for immediate delivery to raise delivery errors.
+ # config.action_mailer.raise_delivery_errors = false
+
+ # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
+ # the I18n.default_locale when a translation cannot be found).
+ config.i18n.fallbacks = true
+
+ # Don't log any deprecations.
+ config.active_support.report_deprecations = false
+
+ # Use default logging formatter so that PID and timestamp are not suppressed.
+ config.log_formatter = ::Logger::Formatter.new
+
+ # Use a different logger for distributed setups.
+ # require "syslog/logger"
+ # config.logger = ActiveSupport::TaggedLogging.new(Syslog::Logger.new "app-name")
+
+ if ENV["RAILS_LOG_TO_STDOUT"].present?
+ logger = ActiveSupport::Logger.new(STDOUT)
+ logger.formatter = config.log_formatter
+ config.logger = ActiveSupport::TaggedLogging.new(logger)
+ end
+
+ # Do not dump schema after migrations.
+ config.active_record.dump_schema_after_migration = false
+end
diff --git a/config/environments/test.rb b/config/environments/test.rb
new file mode 100644
index 0000000..6ea4d1e
--- /dev/null
+++ b/config/environments/test.rb
@@ -0,0 +1,60 @@
+require "active_support/core_ext/integer/time"
+
+# The test environment is used exclusively to run your application's
+# test suite. You never need to work with it otherwise. Remember that
+# your test database is "scratch space" for the test suite and is wiped
+# and recreated between test runs. Don't rely on the data there!
+
+Rails.application.configure do
+ # Settings specified here will take precedence over those in config/application.rb.
+
+ # Turn false under Spring and add config.action_view.cache_template_loading = true.
+ config.cache_classes = true
+
+ # Eager loading loads your whole application. When running a single test locally,
+ # this probably isn't necessary. It's a good idea to do in a continuous integration
+ # system, or in some way before deploying your code.
+ config.eager_load = ENV["CI"].present?
+
+ # Configure public file server for tests with Cache-Control for performance.
+ config.public_file_server.enabled = true
+ config.public_file_server.headers = {
+ "Cache-Control" => "public, max-age=#{1.hour.to_i}"
+ }
+
+ # Show full error reports and disable caching.
+ config.consider_all_requests_local = true
+ config.action_controller.perform_caching = false
+ config.cache_store = :null_store
+
+ # Raise exceptions instead of rendering exception templates.
+ config.action_dispatch.show_exceptions = false
+
+ # Disable request forgery protection in test environment.
+ config.action_controller.allow_forgery_protection = false
+
+ # Store uploaded files on the local file system in a temporary directory.
+ config.active_storage.service = :test
+
+ config.action_mailer.perform_caching = false
+
+ # Tell Action Mailer not to deliver emails to the real world.
+ # The :test delivery method accumulates sent emails in the
+ # ActionMailer::Base.deliveries array.
+ config.action_mailer.delivery_method = :test
+
+ # Print deprecation notices to the stderr.
+ config.active_support.deprecation = :stderr
+
+ # Raise exceptions for disallowed deprecations.
+ config.active_support.disallowed_deprecation = :raise
+
+ # Tell Active Support which deprecation messages to disallow.
+ config.active_support.disallowed_deprecation_warnings = []
+
+ # Raises error for missing translations.
+ # config.i18n.raise_on_missing_translations = true
+
+ # Annotate rendered view with file names.
+ # config.action_view.annotate_rendered_view_with_filenames = true
+end
diff --git a/config/importmap.rb b/config/importmap.rb
new file mode 100644
index 0000000..8dce42d
--- /dev/null
+++ b/config/importmap.rb
@@ -0,0 +1,7 @@
+# Pin npm packages by running ./bin/importmap
+
+pin "application", preload: true
+pin "@hotwired/turbo-rails", to: "turbo.min.js", preload: true
+pin "@hotwired/stimulus", to: "stimulus.min.js", preload: true
+pin "@hotwired/stimulus-loading", to: "stimulus-loading.js", preload: true
+pin_all_from "app/javascript/controllers", under: "controllers"
diff --git a/config/initializers/assets.rb b/config/initializers/assets.rb
new file mode 100644
index 0000000..2eeef96
--- /dev/null
+++ b/config/initializers/assets.rb
@@ -0,0 +1,12 @@
+# Be sure to restart your server when you modify this file.
+
+# Version of your assets, change this if you want to expire all your assets.
+Rails.application.config.assets.version = "1.0"
+
+# Add additional assets to the asset load path.
+# Rails.application.config.assets.paths << Emoji.images_path
+
+# Precompile additional assets.
+# application.js, application.css, and all non-JS/CSS in the app/assets
+# folder are already added.
+# Rails.application.config.assets.precompile += %w( admin.js admin.css )
diff --git a/config/initializers/content_security_policy.rb b/config/initializers/content_security_policy.rb
new file mode 100644
index 0000000..3621f97
--- /dev/null
+++ b/config/initializers/content_security_policy.rb
@@ -0,0 +1,26 @@
+# Be sure to restart your server when you modify this file.
+
+# Define an application-wide content security policy
+# For further information see the following documentation
+# https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy
+
+# Rails.application.configure do
+# config.content_security_policy do |policy|
+# policy.default_src :self, :https
+# policy.font_src :self, :https, :data
+# policy.img_src :self, :https, :data
+# policy.object_src :none
+# policy.script_src :self, :https
+# policy.style_src :self, :https
+# # Specify URI for violation reports
+# # policy.report_uri "/csp-violation-report-endpoint"
+# end
+#
+# # Generate session nonces for permitted importmap and inline scripts
+# config.content_security_policy_nonce_generator = ->(request) { request.session.id.to_s }
+# config.content_security_policy_nonce_directives = %w(script-src)
+#
+# # Report CSP violations to a specified URI. See:
+# # https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy-Report-Only
+# # config.content_security_policy_report_only = true
+# end
diff --git a/config/initializers/filter_parameter_logging.rb b/config/initializers/filter_parameter_logging.rb
new file mode 100644
index 0000000..adc6568
--- /dev/null
+++ b/config/initializers/filter_parameter_logging.rb
@@ -0,0 +1,8 @@
+# Be sure to restart your server when you modify this file.
+
+# Configure parameters to be filtered from the log file. Use this to limit dissemination of
+# sensitive information. See the ActiveSupport::ParameterFilter documentation for supported
+# notations and behaviors.
+Rails.application.config.filter_parameters += [
+ :passw, :secret, :token, :_key, :crypt, :salt, :certificate, :otp, :ssn
+]
diff --git a/config/initializers/inflections.rb b/config/initializers/inflections.rb
new file mode 100644
index 0000000..3860f65
--- /dev/null
+++ b/config/initializers/inflections.rb
@@ -0,0 +1,16 @@
+# Be sure to restart your server when you modify this file.
+
+# Add new inflection rules using the following format. Inflections
+# are locale specific, and you may define rules for as many different
+# locales as you wish. All of these examples are active by default:
+# ActiveSupport::Inflector.inflections(:en) do |inflect|
+# inflect.plural /^(ox)$/i, "\\1en"
+# inflect.singular /^(ox)en/i, "\\1"
+# inflect.irregular "person", "people"
+# inflect.uncountable %w( fish sheep )
+# end
+
+# These inflection rules are supported but not enabled by default:
+# ActiveSupport::Inflector.inflections(:en) do |inflect|
+# inflect.acronym "RESTful"
+# end
diff --git a/config/initializers/permissions_policy.rb b/config/initializers/permissions_policy.rb
new file mode 100644
index 0000000..00f64d7
--- /dev/null
+++ b/config/initializers/permissions_policy.rb
@@ -0,0 +1,11 @@
+# Define an application-wide HTTP permissions policy. For further
+# information see https://developers.google.com/web/updates/2018/06/feature-policy
+#
+# Rails.application.config.permissions_policy do |f|
+# f.camera :none
+# f.gyroscope :none
+# f.microphone :none
+# f.usb :none
+# f.fullscreen :self
+# f.payment :self, "https://secure.example.com"
+# end
diff --git a/config/locales/en.yml b/config/locales/en.yml
new file mode 100644
index 0000000..8ca56fc
--- /dev/null
+++ b/config/locales/en.yml
@@ -0,0 +1,33 @@
+# Files in the config/locales directory are used for internationalization
+# and are automatically loaded by Rails. If you want to use locales other
+# than English, add the necessary files in this directory.
+#
+# To use the locales, use `I18n.t`:
+#
+# I18n.t "hello"
+#
+# In views, this is aliased to just `t`:
+#
+# <%= t("hello") %>
+#
+# To use a different locale, set it with `I18n.locale`:
+#
+# I18n.locale = :es
+#
+# This would use the information in config/locales/es.yml.
+#
+# The following keys must be escaped otherwise they will not be retrieved by
+# the default I18n backend:
+#
+# true, false, on, off, yes, no
+#
+# Instead, surround them with single quotes.
+#
+# en:
+# "true": "foo"
+#
+# To learn more, please read the Rails Internationalization guide
+# available at https://guides.rubyonrails.org/i18n.html.
+
+en:
+ hello: "Hello world"
diff --git a/config/puma.rb b/config/puma.rb
new file mode 100644
index 0000000..daaf036
--- /dev/null
+++ b/config/puma.rb
@@ -0,0 +1,43 @@
+# Puma can serve each request in a thread from an internal thread pool.
+# The `threads` method setting takes two numbers: a minimum and maximum.
+# Any libraries that use thread pools should be configured to match
+# the maximum value specified for Puma. Default is set to 5 threads for minimum
+# and maximum; this matches the default thread size of Active Record.
+#
+max_threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }
+min_threads_count = ENV.fetch("RAILS_MIN_THREADS") { max_threads_count }
+threads min_threads_count, max_threads_count
+
+# Specifies the `worker_timeout` threshold that Puma will use to wait before
+# terminating a worker in development environments.
+#
+worker_timeout 3600 if ENV.fetch("RAILS_ENV", "development") == "development"
+
+# Specifies the `port` that Puma will listen on to receive requests; default is 3000.
+#
+port ENV.fetch("PORT") { 3000 }
+
+# Specifies the `environment` that Puma will run in.
+#
+environment ENV.fetch("RAILS_ENV") { "development" }
+
+# Specifies the `pidfile` that Puma will use.
+pidfile ENV.fetch("PIDFILE") { "tmp/pids/server.pid" }
+
+# Specifies the number of `workers` to boot in clustered mode.
+# Workers are forked web server processes. If using threads and workers together
+# the concurrency of the application would be max `threads` * `workers`.
+# Workers do not work on JRuby or Windows (both of which do not support
+# processes).
+#
+# workers ENV.fetch("WEB_CONCURRENCY") { 2 }
+
+# Use the `preload_app!` method when specifying a `workers` number.
+# This directive tells Puma to first boot the application and load code
+# before forking the application. This takes advantage of Copy On Write
+# process behavior so workers use less memory.
+#
+# preload_app!
+
+# Allow puma to be restarted by `bin/rails restart` command.
+plugin :tmp_restart
diff --git a/config/routes.rb b/config/routes.rb
new file mode 100644
index 0000000..262ffd5
--- /dev/null
+++ b/config/routes.rb
@@ -0,0 +1,6 @@
+Rails.application.routes.draw do
+ # Define your application routes per the DSL in https://guides.rubyonrails.org/routing.html
+
+ # Defines the root path route ("/")
+ # root "articles#index"
+end
diff --git a/config/storage.yml b/config/storage.yml
new file mode 100644
index 0000000..4942ab6
--- /dev/null
+++ b/config/storage.yml
@@ -0,0 +1,34 @@
+test:
+ service: Disk
+ root: <%= Rails.root.join("tmp/storage") %>
+
+local:
+ service: Disk
+ root: <%= Rails.root.join("storage") %>
+
+# Use bin/rails credentials:edit to set the AWS secrets (as aws:access_key_id|secret_access_key)
+# amazon:
+# service: S3
+# access_key_id: <%= Rails.application.credentials.dig(:aws, :access_key_id) %>
+# secret_access_key: <%= Rails.application.credentials.dig(:aws, :secret_access_key) %>
+# region: us-east-1
+# bucket: your_own_bucket-<%= Rails.env %>
+
+# Remember not to checkin your GCS keyfile to a repository
+# google:
+# service: GCS
+# project: your_project
+# credentials: <%= Rails.root.join("path/to/gcs.keyfile") %>
+# bucket: your_own_bucket-<%= Rails.env %>
+
+# Use bin/rails credentials:edit to set the Azure Storage secret (as azure_storage:storage_access_key)
+# microsoft:
+# service: AzureStorage
+# storage_account_name: your_account_name
+# storage_access_key: <%= Rails.application.credentials.dig(:azure_storage, :storage_access_key) %>
+# container: your_container_name-<%= Rails.env %>
+
+# mirror:
+# service: Mirror
+# primary: local
+# mirrors: [ amazon, google, microsoft ]
diff --git a/css/assignments.less b/css/assignments.less
deleted file mode 100644
index b4c055a..0000000
--- a/css/assignments.less
+++ /dev/null
@@ -1,137 +0,0 @@
-@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
-@prim: #333333;
-
-*{
- box-sizing: border-box;
- margin: 0;
- padding: 0;
-
- font-weight: 300;
-}
-
-body{
- font-family: '', sans-serif;
- color: white;
- font-weight: 300;
-
- ::-webkit-input-placeholder { /* WebKit browsers */
- font-family: 'Source Sans Pro', sans-serif;
- color: white;
- font-weight: 300;
- }
- :-moz-placeholder { /* Mozilla Firefox 4 to 18 */
- font-family: 'Source Sans Pro', sans-serif;
- color: white;
- opacity: 1;
- font-weight: 300;
- }
- ::-moz-placeholder { /* Mozilla Firefox 19+ */
- font-family: 'Source Sans Pro', sans-serif;
- color: white;
- opacity: 1;
- font-weight: 300;
- }
- :-ms-input-placeholder { /* Internet Explorer 10+ */
- font-family: 'Source Sans Pro', sans-serif;
- color: white;
- font-weight: 300;
- }
-}
-
-.wrapper{
- background: #333333;
-background: -webkit-linear-gradient(top left, #333333 0%, #333333 100%);
-background: -moz-linear-gradient(top left, #333333 0%, #333333 100%);
-background: -o-linear-gradient(top left, #333333 0%, #333333 100%);
-background: linear-gradient(to bottom right, #333333 0%, #333333 100%);
- position: relative;
- height: 100vh;
- // top: 50%;
- // left: 0;
- // width: 100%;
- // height: 400px;
- // margin-top: -200px;
- overflow: visible;
-
- &.form-success{
- .container{
- h1{
- transform: translateY(85px);
- }
- }
- }
-
- &.form-error{
- .container{
- .assignment{
- button{
- animation: shake 0.82s cubic-bezier(.36,.07,.19,.97) both;
- @keyframes shake {
- 10%, 90% {
- transform: translate3d(-1px, 0, 0);
- }
- 20%, 80% {
- transform: translate3d(2px, 0, 0);
- }
- 30%, 50%, 70% {
- transform: translate3d(-4px, 0, 0);
- }
- 40%, 60% {
- transform: translate3d(4px, 0, 0);
- }
- }
- }
- }
- }
- }
-}
-
-.container{
- max-width: 600px;
- margin: 0 auto;
- padding: 80px 0;
- height: 400px;
- text-align: center;
-
- h1{
- font-size: 40px;
- transition-duration: 1s;
- transition-timing-function: ease-in-put;
- font-weight: 200;
- }
-}
-
-.assignment{
- padding: 20px 0;
- position: relative;
- z-index: 2;
-
- button{
- appearance: none;
- outline: 0;
- // make backgournd color a gradient
- background: #50a3a2;
- background: -webkit-linear-gradient(top left, #50a3a2 0%, #53e3a6 100%);
- background: -moz-linear-gradient(top left, #50a3a2 0%, #53e3a6 100%);
- background: -o-linear-gradient(top left, #50a3a2 0%, #53e3a6 100%);
- background: linear-gradient(to bottom right, #50a3a2 0%, #53e3a6 100%);
-
- border: 0;
- padding: 10px 15px;
- color: @prim;
- border-radius: 3px;
- width: 600px;
- cursor: pointer;
- font-size: 18px;
- transition-duration: 0.25s;
- margin-bottom: 20px;
-
- &:hover{
- // add a shadow
- box-shadow: 0px 5px 10px rgba(0,0,0,0.25);
-
- // change the background color
- background: #53e3a6;
- }
- }
-}
\ No newline at end of file
diff --git a/css/login.less b/css/login.less
deleted file mode 100644
index dcb860e..0000000
--- a/css/login.less
+++ /dev/null
@@ -1,309 +0,0 @@
-@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
-@prim: #333333;
-
-*{
- box-sizing: border-box;
- margin: 0;
- padding: 0;
-
- font-weight: 300;
-}
-
-body{
- font-family: '', sans-serif;
- color: white;
- font-weight: 300;
-
- ::-webkit-input-placeholder { /* WebKit browsers */
- font-family: 'Source Sans Pro', sans-serif;
- color: white;
- font-weight: 300;
- }
- :-moz-placeholder { /* Mozilla Firefox 4 to 18 */
- font-family: 'Source Sans Pro', sans-serif;
- color: white;
- opacity: 1;
- font-weight: 300;
- }
- ::-moz-placeholder { /* Mozilla Firefox 19+ */
- font-family: 'Source Sans Pro', sans-serif;
- color: white;
- opacity: 1;
- font-weight: 300;
- }
- :-ms-input-placeholder { /* Internet Explorer 10+ */
- font-family: 'Source Sans Pro', sans-serif;
- color: white;
- font-weight: 300;
- }
-}
-
-.wrapper{
- background: #333333;
-background: -webkit-linear-gradient(top left, #333333 0%, #333333 100%);
-background: -moz-linear-gradient(top left, #333333 0%, #333333 100%);
-background: -o-linear-gradient(top left, #333333 0%, #333333 100%);
-background: linear-gradient(to bottom right, #333333 0%, #333333 100%);
-
- position: relative;
- height: 100vh;
- // top: 50%;
- // left: 0;
- // width: 100%;
- // height: 400px;
- // margin-top: -200px;
- overflow: hidden;
-
- &.form-success{
- .container{
- h1{
- transform: translateY(85px);
- }
- }
- }
-
- // add shake
- &.form-error{
- // add animation to container
- .container{
- h1{
- animation: shake 0.82s cubic-bezier(.36,.07,.19,.97) both;
- @keyframes shake {
- 10%, 90% {
- transform: translate3d(-1px, 0, 0);
- }
- 20%, 80% {
- transform: translate3d(2px, 0, 0);
- }
- 30%, 50%, 70% {
- transform: translate3d(-4px, 0, 0);
- }
- 40%, 60% {
- transform: translate3d(4px, 0, 0);
- }
- }
- }
- }
- }
-}
-
-.container{
- max-width: 600px;
- margin: 0 auto;
- padding: 80px 0;
- height: 400px;
- text-align: center;
-
- h1{
- font-size: 40px;
- transition-duration: 1s;
- transition-timing-function: ease-in-put;
- font-weight: 200;
- }
-}
-
-form{
- padding: 20px 0;
- position: relative;
- z-index: 2;
-
- input{
- display: block;
- appearance: none;
- outline: 0;
- border: 1px solid fade(white, 40%);
- background-color: fade(white, 20%);
- width: 250px;
-
- border-radius: 3px;
- padding: 10px 15px;
- margin: 0 auto 10px auto;
- display: block;
- text-align: center;
- font-size: 18px;
-
- color: white;
-
- transition-duration: 0.25s;
- font-weight: 300;
-
- &:hover{
- background-color: fade(white, 40%);
- }
-
- &:focus{
- background-color: white;
- width: 300px;
-
- color: @prim;
- }
- }
-
- button{
- appearance: none;
- outline: 0;
- background-color: white;
- border: 0;
- padding: 10px 15px;
- color: @prim;
- border-radius: 3px;
- width: 250px;
- cursor: pointer;
- font-size: 18px;
- transition-duration: 0.25s;
-
- &:hover{
- background-color: rgb(245, 247, 249);
- }
- }
-}
-
-// // fade the form on success
-// .form-success{
-// .container{
-// h1{
-// transform: translateY(0px);
-// }
-// }
-// }
-
-// // form error shake animation
-// .form-error{
-// .container{
-// h1{
-// animation: formError 0.5s;
-// }
-// }
-// }
-
-.bg-bubbles{
- position: absolute;
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
-
- z-index: 1;
-
- li{
- position: absolute;
- // list-style: none;
- display: block;
- width: 40px;
- height: 40px;
- background-color: fade(white, 15%);
- // bottom: -160px;
- // make the squares spawn from the bottom of the screen determined by the height of the screen
- // bottom: calc(-100% + 100px);
- bottom: calc(100% - 1100px);
-
- -webkit-animation: square 25s infinite;
- animation: square 25s infinite;
-
- -webkit-transition-timing-function: linear;
- transition-timing-function: linear;
-
- &:nth-child(1){
- left: 10%;
- }
-
- &:nth-child(2){
- left: 20%;
-
- width: 80px;
- height: 80px;
-
- animation-delay: 2s;
- animation-duration: 17s;
- }
-
- &:nth-child(3){
- left: 25%;
- animation-delay: 4s;
- }
-
- &:nth-child(4){
- left: 40%;
- width: 60px;
- height: 60px;
-
- animation-duration: 22s;
-
- background-color: fade(white, 25%);
- }
-
- &:nth-child(5){
- left: 70%;
- }
-
- &:nth-child(6){
- left: 80%;
- width: 120px;
- height: 120px;
-
- animation-delay: 3s;
- background-color: fade(white, 20%);
- }
-
- &:nth-child(7){
- left: 32%;
- width: 160px;
- height: 160px;
-
- animation-delay: 7s;
- }
-
- &:nth-child(8){
- left: 55%;
- width: 20px;
- height: 20px;
-
- animation-delay: 15s;
- animation-duration: 40s;
- }
-
- &:nth-child(9){
- left: 25%;
- width: 10px;
- height: 10px;
-
- animation-delay: 2s;
- animation-duration: 40s;
- background-color: fade(white, 30%);
- }
-
- &:nth-child(10){
- left: 90%;
- width: 160px;
- height: 160px;
-
- animation-delay: 11s;
- }
- }
-}
-
-// add sqaure animation that moves from bottom up and rotates then fades with steps
-
-
-@-webkit-keyframes square {
- 0% { transform: translateY(0); }
- 100% { transform: translateY(-700px) rotate(600deg); }
- 100% { transform: translateY(-1100px) rotate(600deg); }
-}
-@keyframes square {
- 0% { transform: translateY(0); }
- 90% { transform: translateY(-1100px) rotate(600deg); }
-}
-
-// form error shake animation
-@-webkit-keyframes formError {
- 0% { transform: translateY(0); }
- 100% { transform: translateY(-10px) rotate(5deg); }
- 100% { transform: translateY(0) rotate(-5deg); }
-}
-@keyframes formError {
- 0% { transform: translateY(0); }
- 100% { transform: translateY(-10px) rotate(5deg); }
- 100% { transform: translateY(0) rotate(-5deg); }
-}
-
diff --git a/css/styles.css b/css/styles.css
deleted file mode 100644
index b1cc627..0000000
--- a/css/styles.css
+++ /dev/null
@@ -1,307 +0,0 @@
-* {
- padding: 0;
- margin: 0;
- box-sizing: border-box;
-}
-
-/* Navbar */
-.header {
- overflow: hidden;
- background-color: #333333;
- padding: 20px 10px;
- transition: all 0.2s ease-in-out;
- }
-
- .header a {
- float: left;
- color: #BBBBBB;
- text-shadow: 3px 2px 2px rgba(199, 130, 59, 0.15);
- text-align: center;
- padding: 12px;
- text-decoration: none;
- font-size: 18px;
- line-height: 25px;
- border-radius: 4px;
- transition: all 0.2s ease-in-out;
- }
-
- .header a.logo {
- font-size: 25px;
- font-weight: bold;
- }
-
- .header a:hover {
- transform: scale(1.1);
- cursor: pointer;
- }
-
- .header a.active {
- background-color: #BBBBBB;
- color: black;
- }
-
- .header-right {
- float: right;
- }
-
-/* Overlay */
-.overlay {
- height: 100%;
- width: 0;
- position: fixed;
- z-index: 1;
- top: 0;
- left: 0;
- background-color: rgb(0,0,0);
- background-color: rgba(0,0,0, 0.9);
- overflow-x: hidden;
- transition: 0.5s;
- }
-
- .overlay-content {
- position: relative;
- top: 25%;
- width: 100%;
- text-align: center;
- margin-top: 30px;
- }
-
- .overlay a {
- padding: 8px;
- text-decoration: none;
- font-size: 36px;
- color: #818181;
- display: block;
- transition: 0.3s;
- }
-
- .overlay a:hover, .overlay a:focus {
- color: #f1f1f1;
- }
-
- .overlay .closebtn {
- position: absolute;
- top: 20px;
- right: 45px;
- font-size: 60px;
- }
-
-/* Style */
-html {
- background-color: #333333;
- color: #BBBBBB;
- font-family: 'Montserrat', sans-serif;
- font-weight: 400;
- font-size: 1vh;
- text-shadow: 3px 2px 2px rgba(199, 130, 59, 0.15);
- -ms-overflow-style: none; /* Hide scrollbar for Internet Explorer and Edge */
- scrollbar-width: none; /* Hide scrollbar for Firefox */
- scroll-behavior: smooth;
-
- overflow: scroll;
- overflow-x: hidden;
- }
-
- /* Hide scrollbar for Chrome, Safari and Opera */
- .html::-webkit-scrollbar {
- width: 0;
- background: transparent; /* Optional: just make scrollbar invisible */
- }
-
-#end__of__page {
- margin-bottom: -30vh;
-}
-
-.centered {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- min-height: 100vh;
-}
-
-.row {
- display: flex;
- flex-direction: row;
- justify-content: center;
- align-items: center;
-}
-
-.highlight {
- background-color: #EEEEEE;
- border-radius: 20px;
- line-height: 1.5;
- padding-right: 0.9vw;
- padding-left: 0.9vw;
- font-weight: 520;
- text-shadow: none;
- box-shadow: 3px 2px 2px rgba(199, 130, 59, 0.15);
-}
-
-.hero__header {
- font-size: 6vw;
- font-weight: 400;
-}
-
-.normal__header {
- font-size: 1vw;
- font-weight: 400;
-}
-
-.divider__line {
- height: 4vw;
-}
-
-.about__header {
- font-size: 3vw;
- font-weight: 400;
-}
-
-.logo {
- transition: all 0.2s ease-in-out;
-}
-
-.logo:hover {
- transform: scale(1.1);
- cursor: pointer;
-}
-
-.logo__image {
- margin-left: 2vw;
- margin-right: 2vw;
- width: 10vw;
-}
-
-/* blog */
-.blog_row {
- display: inline-flex;
- flex-direction: row;
- justify-content: center;
- align-items: center;
- margin-top: 2vw;
- margin-bottom: 2vw;
- gap: 12px;
- flex-wrap: wrap;
-}
-
-.blog {
- background: grey;
- width: 250px;
- height: 250px;
- border: 150px;
- border-radius: 20px;
- line-height: 1.5;
- padding-right: 0.9vw;
- padding-left: 0.9vw;
- font-weight: 520;
- text-shadow: none;
- box-shadow: 3px 2px 2px rgba(199, 130, 59, 0.15);
- transition: all 0.2s ease-in-out;
- }
-
- .blog:hover {
- transform: scale(1.1);
- cursor: pointer;
- }
-
- .blog__image {
- margin-left: 2vw;
- margin-right: 2vw;
- width: 10vw;
- }
-
-/* Login */
-#login-holder {
- width: 50%;
- height: 70%;
- display: grid;
- justify-items: center;
- align-items: center;
- background-color: grey;
- border-radius: 7px;
- box-shadow: 0px 0px 5px 2px black;
-}
-
-#login-error-msg-holder {
- width: 100%;
- height: 100%;
- display: grid;
- justify-items: center;
- align-items: center;
-}
-
-#login-error-msg {
- width: 23%;
- text-align: center;
- margin: 0;
- padding: 5px;
- font-size: 12px;
- font-weight: bold;
- color: #8a0000;
- border: 1px solid #8a0000;
- background-color: #e58f8f;
- opacity: 0;
-}
-
-#error-msg-second-line {
- display: block;
-}
-
-#login-form {
- align-self: flex-start;
- display: grid;
- justify-items: center;
- align-items: center;
-}
-
-.login-form-field::placeholder {
- color: #3a3a3a;
-}
-
-.login-form-field {
- border: none;
- border-bottom: 1px solid #3a3a3a;
- margin-bottom: 10px;
- border-radius: 3px;
- outline: none;
- padding: 0px 0px 5px 5px;
-}
-
-#login-form-submit {
- width: 100%;
- padding: 7px;
- border: none;
- border-radius: 5px;
- color: white;
- font-weight: bold;
- background-color: #3a3a3a;
- cursor: pointer;
- outline: none;
-}
-
-.login-form:hover {
- background-color: #3a3a3a;
-}
-
-
-@media only screen and (max-width: 1024px) {
- .hero__header {
- font-size: 12vw;
- font-weight: 400;
- }
-
- .about__header {
- font-size: 5vw;
- font-weight: 400;
- }
-
- .divider__line {
- height: 8vw;
- }
-
- .logo__image {
- margin-left: 2vw;
- margin-right: 2vw;
- width: 14vw;
- }
-}
diff --git a/db/seeds.rb b/db/seeds.rb
new file mode 100644
index 0000000..bc25fce
--- /dev/null
+++ b/db/seeds.rb
@@ -0,0 +1,7 @@
+# This file should contain all the record creation needed to seed the database with its default values.
+# The data can then be loaded with the bin/rails db:seed command (or created alongside the database with db:setup).
+#
+# Examples:
+#
+# movies = Movie.create([{ name: "Star Wars" }, { name: "Lord of the Rings" }])
+# Character.create(name: "Luke", movie: movies.first)
diff --git a/download.html b/download.html
deleted file mode 100644
index 2ed1996..0000000
--- a/download.html
+++ /dev/null
@@ -1,57 +0,0 @@
-
-
-
- Download YT
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/images/colors/colors.png b/images/colors/colors.png
deleted file mode 100644
index 87d9047..0000000
Binary files a/images/colors/colors.png and /dev/null differ
diff --git a/images/elements/ai/line_long.ai b/images/elements/ai/line_long.ai
deleted file mode 100644
index 66f4400..0000000
--- a/images/elements/ai/line_long.ai
+++ /dev/null
@@ -1,1412 +0,0 @@
-%PDF-1.6
%âãÏÓ
-1 0 obj
<>/OCGs[24 0 R]>>/Pages 3 0 R/Type/Catalog>>
endobj
2 0 obj
<>stream
-
-
-
-
- application/pdf
-
-
- line_long
-
-
- Adobe Illustrator 25.2 (Windows)
- 2021-06-03T09:50:44-04:00
- 2021-06-03T09:50:45-04:00
- 2021-06-03T09:50:45-04:00
-
-
-
- 256
- 8
- JPEG
- /9j/4AAQSkZJRgABAgEASABIAAD/7QAsUGhvdG9zaG9wIDMuMAA4QklNA+0AAAAAABAASAAAAAEA
AQBIAAAAAQAB/+4ADkFkb2JlAGTAAAAAAf/bAIQABgQEBAUEBgUFBgkGBQYJCwgGBggLDAoKCwoK
DBAMDAwMDAwQDA4PEA8ODBMTFBQTExwbGxscHx8fHx8fHx8fHwEHBwcNDA0YEBAYGhURFRofHx8f
Hx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8f/8AAEQgACAEAAwER
AAIRAQMRAf/EAaIAAAAHAQEBAQEAAAAAAAAAAAQFAwIGAQAHCAkKCwEAAgIDAQEBAQEAAAAAAAAA
AQACAwQFBgcICQoLEAACAQMDAgQCBgcDBAIGAnMBAgMRBAAFIRIxQVEGE2EicYEUMpGhBxWxQiPB
UtHhMxZi8CRygvElQzRTkqKyY3PCNUQnk6OzNhdUZHTD0uIIJoMJChgZhJRFRqS0VtNVKBry4/PE
1OT0ZXWFlaW1xdXl9WZ2hpamtsbW5vY3R1dnd4eXp7fH1+f3OEhYaHiImKi4yNjo+Ck5SVlpeYmZ
qbnJ2en5KjpKWmp6ipqqusra6voRAAICAQIDBQUEBQYECAMDbQEAAhEDBCESMUEFURNhIgZxgZEy
obHwFMHR4SNCFVJicvEzJDRDghaSUyWiY7LCB3PSNeJEgxdUkwgJChgZJjZFGidkdFU38qOzwygp
0+PzhJSktMTU5PRldYWVpbXF1eX1RlZmdoaWprbG1ub2R1dnd4eXp7fH1+f3OEhYaHiImKi4yNjo
+DlJWWl5iZmpucnZ6fkqOkpaanqKmqq6ytrq+v/aAAwDAQACEQMRAD8A9IXGhX8s8kiavdRK7Flj
UpxUE14j4egyo4zfMufDWQAAOOB+f61P/Dupf9Xu7+9P+acHhS/nFl+dh/qUPt/W7/Dupf8AV7u/
vT/mnHwpfziv52H+pQ+39bv8O6l/1e7v70/5px8KX84r+dh/qUPt/W7/AA7qX/V7u/vT/mnHwpfz
iv52H+pQ+39bv8O6l/1e7v70/wCacfCl/OK/nYf6lD7f1u/w7qX/AFe7v70/5px8KX84r+dh/qUP
t/W7/Dupf9Xu7+9P+acfCl/OK/nYf6lD7f1u/wAO6l/1e7v70/5px8KX84r+dh/qUPt/W7/Dupf9
Xu7+9P8AmnHwpfziv52H+pQ+39bv8O6l/wBXu7+9P+acfCl/OK/nYf6lD7f1u/w7qX/V7u/vT/mn
Hwpfziv52H+pQ+39bv8ADupf9Xu7+9P+acfCl/OK/nYf6lD7f1u/w7qX/V7u/vT/AJpx8KX84r+d
h/qUPt/W7/Dupf8AV7u/vT/mnHwpfziv52H+pQ+39bv8O6l/1e7v70/5px8KX84r+dh/qUPt/W7/
AA7qX/V7u/vT/mnHwpfziv52H+pQ+39bv8O6l/1e7v70/wCacfCl/OK/nYf6lD7f1u/w7qX/AFe7
v70/5px8KX84r+dh/qUPt/W7/Dupf9Xu7+9P+acfCl/OK/nYf6lD7f1u/wAO6l/1e7v70/5px8KX
84r+dh/qUPt/W7/Dupf9Xu7+9P8AmnHwpfziv52H+pQ+39bv8O6l/wBXu7+9P+acfCl/OK/nYf6l
D7f1u/w7qX/V7u/vT/mnHwpfziv52H+pQ+39bv8ADupf9Xu7+9P+acfCl/OK/nYf6lD7f1u/w7qX
/V7u/vT/AJpx8KX84r+dh/qUPt/W7/Dupf8AV7u/vT/mnHwpfziv52H+pQ+39bv8O6l/1e7v70/5
px8KX84r+dh/qUPt/W7/AA7qX/V7u/vT/mnHwpfziv52H+pQ+39bv8O6l/1e7v70/wCacfCl/OK/
nYf6lD7f1u/w7qX/AFe7v70/5px8KX84r+dh/qUPt/WitO0m8tJzLLqM92pUr6UvHiKkGuwG+2Sj
Ag87ac+ojONCEY+5/9k=
-
-
-
- proof:pdf
- uuid:65E6390686CF11DBA6E2D887CEACB407
- xmp.did:7b679679-76ea-e149-9c78-f08f125870af
- uuid:120d8eb1-7bae-47ea-a507-d2e36c18b7e7
-
- uuid:977b090f-124e-4650-b8e8-7ff4b2824aaf
- xmp.did:4dde2ac8-f8f9-df49-be5f-86a697879804
- uuid:65E6390686CF11DBA6E2D887CEACB407
- proof:pdf
-
-
-
-
- saved
- xmp.iid:3e405b58-9478-2948-be8e-e8b65ff81f1e
- 2021-06-01T13:28:44-04:00
- Adobe Illustrator 25.2 (Windows)
- /
-
-
- saved
- xmp.iid:7b679679-76ea-e149-9c78-f08f125870af
- 2021-06-03T09:46:52-04:00
- Adobe Illustrator 25.2 (Windows)
- /
-
-
-
- Web
- Document
- AIRobin
- 1
- True
- False
-
- 784.000000
- 66.000000
- Pixels
-
-
-
- Cyan
- Magenta
- Yellow
- Black
-
-
-
-
-
- Default Swatch Group
- 0
-
-
-
- White
- RGB
- PROCESS
- 255
- 255
- 255
-
-
- Black
- RGB
- PROCESS
- 0
- 0
- 0
-
-
- RGB Red
- RGB
- PROCESS
- 255
- 0
- 0
-
-
- RGB Yellow
- RGB
- PROCESS
- 255
- 255
- 0
-
-
- RGB Green
- RGB
- PROCESS
- 0
- 255
- 0
-
-
- RGB Cyan
- RGB
- PROCESS
- 0
- 255
- 255
-
-
- RGB Blue
- RGB
- PROCESS
- 0
- 0
- 255
-
-
- RGB Magenta
- RGB
- PROCESS
- 255
- 0
- 255
-
-
- R=193 G=39 B=45
- RGB
- PROCESS
- 193
- 39
- 45
-
-
- R=237 G=28 B=36
- RGB
- PROCESS
- 237
- 28
- 36
-
-
- R=241 G=90 B=36
- RGB
- PROCESS
- 241
- 90
- 36
-
-
- R=247 G=147 B=30
- RGB
- PROCESS
- 247
- 147
- 30
-
-
- R=251 G=176 B=59
- RGB
- PROCESS
- 251
- 176
- 59
-
-
- R=252 G=238 B=33
- RGB
- PROCESS
- 252
- 238
- 33
-
-
- R=217 G=224 B=33
- RGB
- PROCESS
- 217
- 224
- 33
-
-
- R=140 G=198 B=63
- RGB
- PROCESS
- 140
- 198
- 63
-
-
- R=57 G=181 B=74
- RGB
- PROCESS
- 57
- 181
- 74
-
-
- R=0 G=146 B=69
- RGB
- PROCESS
- 0
- 146
- 69
-
-
- R=0 G=104 B=55
- RGB
- PROCESS
- 0
- 104
- 55
-
-
- R=34 G=181 B=115
- RGB
- PROCESS
- 34
- 181
- 115
-
-
- R=0 G=169 B=157
- RGB
- PROCESS
- 0
- 169
- 157
-
-
- R=41 G=171 B=226
- RGB
- PROCESS
- 41
- 171
- 226
-
-
- R=0 G=113 B=188
- RGB
- PROCESS
- 0
- 113
- 188
-
-
- R=46 G=49 B=146
- RGB
- PROCESS
- 46
- 49
- 146
-
-
- R=27 G=20 B=100
- RGB
- PROCESS
- 27
- 20
- 100
-
-
- R=102 G=45 B=145
- RGB
- PROCESS
- 102
- 45
- 145
-
-
- R=147 G=39 B=143
- RGB
- PROCESS
- 147
- 39
- 143
-
-
- R=158 G=0 B=93
- RGB
- PROCESS
- 158
- 0
- 93
-
-
- R=212 G=20 B=90
- RGB
- PROCESS
- 212
- 20
- 90
-
-
- R=237 G=30 B=121
- RGB
- PROCESS
- 237
- 30
- 121
-
-
- R=199 G=178 B=153
- RGB
- PROCESS
- 199
- 178
- 153
-
-
- R=153 G=134 B=117
- RGB
- PROCESS
- 153
- 134
- 117
-
-
- R=115 G=99 B=87
- RGB
- PROCESS
- 115
- 99
- 87
-
-
- R=83 G=71 B=65
- RGB
- PROCESS
- 83
- 71
- 65
-
-
- R=198 G=156 B=109
- RGB
- PROCESS
- 198
- 156
- 109
-
-
- R=166 G=124 B=82
- RGB
- PROCESS
- 166
- 124
- 82
-
-
- R=140 G=98 B=57
- RGB
- PROCESS
- 140
- 98
- 57
-
-
- R=117 G=76 B=36
- RGB
- PROCESS
- 117
- 76
- 36
-
-
- R=96 G=56 B=19
- RGB
- PROCESS
- 96
- 56
- 19
-
-
- R=66 G=33 B=11
- RGB
- PROCESS
- 66
- 33
- 11
-
-
-
-
-
- Grays
- 1
-
-
-
- R=0 G=0 B=0
- RGB
- PROCESS
- 0
- 0
- 0
-
-
- R=26 G=26 B=26
- RGB
- PROCESS
- 26
- 26
- 26
-
-
- R=51 G=51 B=51
- RGB
- PROCESS
- 51
- 51
- 51
-
-
- R=77 G=77 B=77
- RGB
- PROCESS
- 77
- 77
- 77
-
-
- R=102 G=102 B=102
- RGB
- PROCESS
- 102
- 102
- 102
-
-
- R=128 G=128 B=128
- RGB
- PROCESS
- 128
- 128
- 128
-
-
- R=153 G=153 B=153
- RGB
- PROCESS
- 153
- 153
- 153
-
-
- R=179 G=179 B=179
- RGB
- PROCESS
- 179
- 179
- 179
-
-
- R=204 G=204 B=204
- RGB
- PROCESS
- 204
- 204
- 204
-
-
- R=230 G=230 B=230
- RGB
- PROCESS
- 230
- 230
- 230
-
-
- R=242 G=242 B=242
- RGB
- PROCESS
- 242
- 242
- 242
-
-
-
-
-
- Web Color Group
- 1
-
-
-
- R=63 G=169 B=245
- RGB
- PROCESS
- 63
- 169
- 245
-
-
- R=122 G=201 B=67
- RGB
- PROCESS
- 122
- 201
- 67
-
-
- R=255 G=147 B=30
- RGB
- PROCESS
- 255
- 147
- 30
-
-
- R=255 G=29 B=37
- RGB
- PROCESS
- 255
- 29
- 37
-
-
- R=255 G=123 B=172
- RGB
- PROCESS
- 255
- 123
- 172
-
-
- R=189 G=204 B=212
- RGB
- PROCESS
- 189
- 204
- 212
-
-
-
-
-
-
- Adobe PDF library 15.00
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-endstream
endobj
3 0 obj
<>
endobj
5 0 obj
<>/Resources<>/ExtGState<>/Properties<>/XObject<>>>/Thumb 32 0 R/TrimBox[0.0 0.0 784.0 66.0]/Type/Page>>
endobj
26 0 obj
<>stream
-H‰,ŽA
-Â0E÷sŠ›I›¦fëTÝXE"x 7ÆR]x}@>ü7¼aÜÉà&SlFƒ,¢ˆÃ:`Åù¾Ë/R·ÏŠÇ‡ÛËÁíŠbœåÌ8#·mRŠì¿‘í(=¾¨®¯îe<º„®mzÜŠTPdPÊxJæÉíÄ?~ n¤7
-endstream
endobj
27 0 obj
<>
endobj
32 0 obj
<>stream
-8;Xp,I2!)*E:ORBi'@0UkQ$,5!s!n^N+`~>
-endstream
endobj
34 0 obj
[/Indexed/DeviceRGB 255 35 0 R]
endobj
35 0 obj
<>stream
-8;X]O>EqN@%''O_@%e@?J;%+8(9e>X=MR6S?i^YgA3=].HDXF.R$lIL@"pJ+EP(%0
-b]6ajmNZn*!='OQZeQ^Y*,=]?C.B+\Ulg9dhD*"iC[;*=3`oP1[!S^)?1)IZ4dup`
-E1r!/,*0[*9.aFIR2&b-C#soRZ7Dl%MLY\.?d>Mn
-6%Q2oYfNRF$$+ON<+]RUJmC0InDZ4OTs0S!saG>GGKUlQ*Q?45:CI&4J'_2j$XKrcYp0n+Xl_nU*O(
-l[$6Nn+Z_Nq0]s7hs]`XX1nZ8&94a\~>
-endstream
endobj
31 0 obj
<>/ExtGState<>/ProcSet[/PDF/ImageC/ImageI]/XObject<>>>/Subtype/Form>>stream
-q
-/GS0 gs
-718 0 0 17 36 22 cm
-/Im0 Do
-Q
-
-endstream
endobj
36 0 obj
<>
endobj
39 0 obj
<>stream
-H‰ìÒ1À0 İÒ
-¡C®> oràï¼L‰™ q3f&ÄÍt¸™7Óáf:ÜL‡›é˜©˜›É˜©Øëv|6Hy üÍ)ä
-endstream
endobj
37 0 obj
[/Indexed 28 0 R 1 41 0 R]
endobj
40 0 obj
<>/Filter/FlateDecode/Height 17/Intent/RelativeColorimetric/Length 299/Name/X/Subtype/Image/Type/XObject/Width 718>>stream
-H‰ì×-ŽÂP†áû“Þ[n*šPnSdE)¦¢Et$
º†&e;À‚`À£P̦¦%!A™ò=kxóåÆ >
-ç€2Î_-éhw @•«)ž=s©Œ„Ñ€¦(|£dŸ³PžÓ,/f y–ÆÖS¢Ÿfc“²ª›v@QÛÔU™XÓ3wü¸\nv‡ã EÇÃn³,cßéjÖÃÉ|½?_oß Ý®çýz>j΄MÛÓåþø èq¿œ¶‹éHl3P÷¶Í¸›¸÷»Y›”UÝ´ÿýšüIÛÔU™X#9cBy6N³¼˜PTäY[O ƺqVÆÂh@S¾Qý4w9éhw @•«)ž1÷=s@µð!~ ¯.Áñ
-endstream
endobj
28 0 obj
[/ICCBased 42 0 R]
endobj
41 0 obj
<>stream
-ÿÿÿÇ‚;
-endstream
endobj
42 0 obj
<>stream
-H‰œ–yTSwÇoÉž•°Ãc
[€°5la‘QIBHØADED„ª•2ÖmtFOE.®cÖ}êÒõ0êè8´×Ž8GNg¦Óïï÷9÷wïïÝß½÷ó '¥ªµÕ0 Ö ÏJŒÅb¤
- 2y.-;!à’ÆK°ZÜ ü‹ž^i½"LÊÀ0ðÿ‰-×é
@8(”µrœ;q®ª7èLöœy¥•&†Qëñq¶4±jž½ç|æ9ÚÄ
-V³)gB£0ñiœWו8#©8wÕ©•õ8_Å٥ʨQãüÜ«QÊj@é&»A)/ÇÙgº>'K‚ó ÈtÕ;\ú”
Ó¥$ÕºF½ZUnÀÜå˜(4TŒ%)ë«”ƒ0C&¯”阤Z£“i˜¿óœ8¦Úbx‘ƒE¡ÁÁBÑ;…ú¯›¿P¦ÞÎӓ̹žAüom?çW=
-€x¯Íú·¶Ò- Œ¯Àòæ[›Ëû 0ñ¾¾øÎ}ø¦y)7ta¾¾õõõ>j¥ÜÇTÐ7úŸ¿@ï¼ÏÇtÜ›ò`qÊ2™±Ê€™ê&¯®ª6ê±ZL®Ä„?â_øóyxg)Ë”z¥ÈçLUáíÖ*ÔuµSkÿSeØO4?׸¸c¯¯Ø°.ò ò· åÒ R´
ßÞô-•’2ð5ßáÞüÜÏ ú÷Sá>Ó£Vš‹“då`r£¾n~ÏôY &à+`œ;ÂA4ˆÉ 䀰ÈA9Ð =¨- t°lÃ`;»Á~pŒƒÁ ðGp| ®[`Lƒ‡`<¯ "AˆYA+äùCb(ЇR¡,¨ *T2B-Ð
-¨ê‡†¡Ðnè÷ÐQètº}MA ï —0Óal»Á¾°ŽSàx ¬‚kà&¸^Á£ð>ø0|>_ƒ'á‡ð,ÂG!"F$H:Rˆ”!z¤éF‘Qd?r9‹\A&‘GÈ”ˆrQ¢áhš‹ÊÑ´íE‡Ñ]èaô4zBgÐ×Á–àE#H ‹*B=¡‹0HØIøˆp†p0MxJ$ùD1„˜D, V›‰½ÄÄÄãÄKÄ»ÄY‰dEò"EÒI2’ÔEÚBÚGúŒt™4MzN¦‘Èþär!YKî ’÷?%_&ß#¿¢°(®”0J:EAi¤ôQÆ(Ç()Ó”WT6U@ æP+¨íÔ!ê~êêmêæD¥eÒÔ´å´!ÚïhŸÓ¦h/èº']B/¢éëèÒÓ¿¢?a0nŒhF!ÃÀXÇØÍ8ÅøšñÜŒkæc&5S˜µ™˜6»lö˜Iaº2c˜K™MÌAæ!æEæ#…寒°d¬VÖë(ëk–Íe‹Øél
»—½‡}Ž}ŸCâ¸qâ9
-N'çÎ)Î].ÂuæJ¸rî
-î÷wšGä xR^¯‡÷[ÞoÆœchžgÞ`>bþ‰ù$á»ñ¥ü*~ÿ ÿ:ÿ¥…EŒ…ÒbÅ~‹ËÏ,m,£-•–Ý–,¯Y¾´Â¬â*6X[ݱF=3ë·YŸ±~dó ·‘ÛtÛ´¹iÛzÚfÙ6Û~`{ÁvÖÎÞ.ÑNg·Åî”Ý#{¾}´}…ý€ý§ö¸‘j‡‡ÏþŠ™c1X6„Æfm“Ž;'_9 œr:œ8Ýq¦:‹ËœœO:ϸ8¸¤¹´¸ìu¹éJq»–»nv=ëúÌMà–ï¶ÊmÜí¾ÀR 4 ö
-n»3Ü£ÜkÜGݯz=Ä•[=¾ô„=ƒ<Ë=GTB(É/ÙSòƒ,]6*›-•–¾W:#—È7Ë*¢ŠÊe¿ò^YDYÙ}U„j£êAyTù`ù#µD=¬þ¶"©b{ųÊôÊ+¬Ê¯: !kJ4Gµm¥ötµ}uCõ%—®K7YV³©fFŸ¢ßYÕ.©=bàá?SŒîƕƩºÈº‘ºçõyõ‡Ø
Ú†žkï5%4ý¦m–7Ÿlqlio™Z³lG+ÔZÚz²Í¹³mzyâò]íÔöÊö?uøuôw|¿"űN»ÎåwW&®ÜÛe֥ﺱ*|ÕöÕèjõê‰5k¶¬yÝèþ¢Ç¯g°ç‡^yïkEk‡Öþ¸®lÝD_pß¶õÄõÚõ×7DmØÕÏîoê¿»1mãál {àûMÅ›Î
nßLÝlÜ<9”úO ¤[þ˜¸™$™™üšhšÕ›B›¯œœ‰œ÷dÒž@ž®ŸŸ‹Ÿú i Ø¡G¡¶¢&¢–££v£æ¤V¤Ç¥8¥©¦¦‹¦ý§n§à¨R¨Ä©7©©ªª««u«é¬\¬ÐD¸®-®¡¯¯‹° °u°ê±`±Ö²K²Â³8³®´%´œµµŠ¶¶y¶ð·h·à¸Y¸Ñ¹J¹Âº;ºµ».»§¼!¼›½½¾
-¾„¾ÿ¿z¿õÀpÀìÁgÁãÂ_ÂÛÃXÃÔÄQÄÎÅKÅÈÆFÆÃÇAÇ¿È=ȼÉ:ɹÊ8Ê·Ë6˶Ì5̵Í5͵Î6ζÏ7ϸÐ9кÑ<ѾÒ?ÒÁÓDÓÆÔIÔËÕNÕÑÖUÖØ×\×àØdØèÙlÙñÚvÚûÛ€ÜÜŠÝÝ–ÞÞ¢ß)߯à6à½áDáÌâSâÛãcãëäsäü儿
æ–çç©è2è¼éFéÐê[êåëpëûì†ííœî(î´ï@ïÌðXðåñrñÿòŒóó§ô4ôÂõPõÞömöû÷Šøø¨ù8ùÇúWúçûwüü˜ý)ýºþKþÜÿmÿÿ ÷„óû
-endstream
endobj
38 0 obj
<>
endobj
43 0 obj
<>
endobj
44 0 obj
[0.0 0.0 0.0]
endobj
45 0 obj
<>/ProcSet[/PDF/ImageB]/XObject<>>>/Subtype/Form>>stream
-q
-/GS0 gs
-718 0 0 17 36 22 cm
-/Im0 Do
-Q
-
-endstream
endobj
46 0 obj
<>
endobj
48 0 obj
<>/Filter/FlateDecode/Height 17/Intent/RelativeColorimetric/Length 299/Name/X/Subtype/Image/Type/XObject/Width 718>>stream
-H‰ì×-ŽÂP†áû“Þ[n*šPnSdE)¦¢Et$
º†&e;À‚`À£P̦¦%!A™ò=kxóåÆ >
-ç€2Î_-éhw @•«)ž=s©Œ„Ñ€¦(|£dŸ³PžÓ,/f y–ÆÖS¢Ÿfc“²ª›v@QÛÔU™XÓ3wü¸\nv‡ã EÇÃn³,cßéjÖÃÉ|½?_oß Ý®çýz>j΄MÛÓåþø èq¿œ¶‹éHl3P÷¶Í¸›¸÷»Y›”UÝ´ÿýšüIÛÔU™X#9cBy6N³¼˜PTäY[O ƺqVÆÂh@S¾Qý4w9éhw @•«)ž1÷=s@µð!~ ¯.Áñ
-endstream
endobj
47 0 obj
<>
endobj
24 0 obj
<>
endobj
49 0 obj
[/View/Design]
endobj
50 0 obj
<>>>
endobj
29 0 obj
<>
endobj
30 0 obj
<>
endobj
8 0 obj
<>
endobj
18 0 obj
<>
endobj
19 0 obj
<>stream
-%!PS-Adobe-3.0
-%%Creator: Adobe Illustrator(R) 24.0
-%%AI8_CreatorVersion: 25.2.3
-%%For: (N8 Dev) ()
-%%Title: (line_long.ai)
-%%CreationDate: 6/3/2021 9:50 AM
-%%Canvassize: 16383
-%%BoundingBox: 604 -551 1322 -534
-%%HiResBoundingBox: 604 -551 1322 -534
-%%DocumentProcessColors: Cyan Magenta Yellow Black
-%AI5_FileFormat 14.0
-%AI12_BuildNumber: 259
-%AI3_ColorUsage: Color
-%AI7_ImageSettings: 0
-%%RGBProcessColor: 0 0 0 ([Registration])
-%AI3_Cropmarks: 568 -573 1352 -507
-%AI3_TemplateBox: 960.5 -540.5 960.5 -540.5
-%AI3_TileBox: 572.519999504089 -837.480000495911 1347.47998046875 -242.52001953125
-%AI3_DocumentPreview: None
-%AI5_ArtSize: 14400 14400
-%AI5_RulerUnits: 6
-%AI24_LargeCanvasScale: 1
-%AI9_ColorModel: 1
-%AI5_ArtFlags: 0 0 0 1 0 0 1 0 0
-%AI5_TargetResolution: 800
-%AI5_NumLayers: 1
-%AI9_OpenToView: 347.192170818506 -210.067615658363 0.975694444444444 2455 1869 18 0 0 111 288 0 0 0 1 1 0 1 1 0 1
-%AI5_OpenViewLayers: 7
-%%PageOrigin:560 -840
-%AI7_GridSettings: 72 8 72 8 1 0 0.800000011920929 0.800000011920929 0.800000011920929 0.899999976158142 0.899999976158142 0.899999976158142
-%AI9_Flatten: 1
-%AI12_CMSettings: 00.MS
-%%EndComments
-
-endstream
endobj
20 0 obj
<>stream
-%AI24_ZStandard_Data(µ/ý X<‘nôEŒ)И&Ãr©òÙ’•mÓ¶u²ÉÏE¹ˆˆ”® ¦£Íg«éù«AjçAM©¯Žé—üjèä4ì²—ži$?›Æó.K·”ŸÇ«$çż¡W!Iam$èQ¬ö&“y›¤GÎMˆX9•„?ÿGnŸ…jÔÑwQåÒã2Q^=Sé]Béñ±Û¸Û£>ˆ‘ôŠÙ°¬¢o'I¦Gõ.hã–¥óï¤÷øüä6èNåç¡å/IÚ03W};iÉÁ†¡ëlò…ø_Ýœmcei2LKSǰ,XŒ^€Á0¸à€ @0x„` ‚JÐà@
H`d A‚ £\p@`°@$@˜Ð a1Aƒ„0¸à€ˆ .8 L0*€ Át`D`L‡
-F ư`c6HŒÂà‚*Ø@âU¶Õ-rõ°<¢¤›>RåAw%‰£è8Ø`dÀ8 5 qŽÑ‘ø‚a¡pbHC-"¡ø¡° p@,®p@€ &@ÐîoåÝø%caÚLÑΘš»¯Rú÷³ßÌú™™ñÞc<×=1Ñ|2=ƒÇ)—î¢EºÎp@क
íÆ6C)Ìj¡_ÿ«¿ë•FŒªy¼;esãË'¡U
-‡‘S±Òèljîl2‹\š¬›f‚‰Åq!q@0¨`U`PœÂ¥ðBb‘H¤ÿœ"ñ¬è®ðU…'ž‘'ˆß`¹î|ADbÁêð€XCë~o_ +•§Àð±Ä•‚Êî‰(,æ°‰šì€8¼\`À™¬BÁiTP T S+hê£}Áæ|u§p7Ø¡!Ý'¯ì€8w¯œJÐ"4Š«Â]W¤ù¬ðDn²ŠdRóSÄqÞXfP&vÑ4S«*C×2«&3¨öeM« '*q‰3$ª …)FÁtÇ?±`JRX8xÄ*è¿)n”I£æŒÚ2"}¦%™Ae7xTf5¿i2±0V¤-DÞ°hjAŠ)ˆ(å€8 pÑEU`P ¹¶‘iò¸ÑÕæE«ÎeÆÏžæº{MeÕYÑõïªÆ×