This commit is contained in:
Sam
2026-06-10 11:51:56 -05:00
commit 66ba338b81
57 changed files with 5509 additions and 0 deletions

134
priv/networks/cs/index.html Normal file
View File

@@ -0,0 +1,134 @@
<forms->
<!-- global -->
<member- id="1" email="samrussell99@pm.me" first-name="Sam" last-name="Russell" password="$argon2id$v=19$m=65536,t=3,p=4$n/8BaBisEnBaQNbkxzs1VA$dvvnupWNtB5w5qTBgEciDsNA6rOgXaEypcEK1A0ndLM" address1="1234 address NW 12th St" city="Austin" state="Texas" zipcode="12345" country="US" county="Austin County" phone="123-456-789" title="CEO" bio="This is my bio" notes="no notes" created="2026-01-15 09:58:01.0072" updated-at="2026-01-15 09:58:01.0072"></member->
<member- id="2" email="freddyjkrueger@gmail.com" first-name="Freddy" last-name="Krueger" password="$argon2id$v=19$m=65536,t=3,p=4$ioAYDPtyUulykMrH9W7q9A$lG43cq6Dj3/n1+bJrkupWpB5Xro3UIQaVd9rjuJJ6nM" address1="1234 address NW 12th St" city="Austin" state="Texas" zipcode="12345" country="US" county="Austin County" phone="123-456-789" title="Villain" bio="This is my bio" notes="no notes" created="2026-01-13 13:38:46.0810" updated-at="2026-01-13 13:38:46.0810"></member->
<member- id="3" email="harmysmarmy@gmail.com" first-name="Harmy" last-name="Smarmy" password="$argon2id$v=19$m=65536,t=3,p=4$FAhGtCtqNAQ19tBYD73wXQ$0AM/khyBFFuX2mv0ieqtGfsXRgtEldWKFwyeV3BA3Xk" address1="1234 address NW 12th St" city="Austin" state="Texas" zipcode="12345" country="US" county="Austin County" phone="123-456-789" title="Associate" bio="This is my bio" notes="no notes" created="2026-01-13 13:41:41.0722" updated-at="2026-01-13 13:41:41.0722"></member->
<member- id="4" email="matiascarulli@gmail.com" first-name="Matias" last-name="Carulli" password="$argon2id$v=19$m=65536,t=3,p=4$U2FsdGVkc3M$08SY0x7DUPwTV12ZckHdNg" address1="1234 address NW 12th St" city="Miramar" state="Florida" zipcode="33029" country="US" county="Broward" phone="123-456-789" title="Developer" bio="This is my bio" image-path="/db/images/users/member-4/profile.png" notes="no notes" created="2026-03-15 13:41:41.0722" updated-at="2026-03-15 13:41:41.0722"></member->
<member- id="5" email="boulder@example.com" first-name="CU" last-name="Boulder" password="$argon2id$v=19$m=65536,t=3,p=4$CQwOYXNwwsLBP1s/zcZNJg$OM/wwVP5U+QUnAEDKAjk5mpvujpOzpT0XkouDcmHT8E" address1="1234 address NW 12th St" city="Austin" state="Texas" zipcode="12345" country="US" county="Austin County" phone="123-456-789" title="Associate" bio="This is my bio" notes="no notes" created="2026-03-26 01:03:18.803016+00" updated-at="2026-03-26 01:03:18.803016+00"></member->
<member- id="6" email="sarah.mcintyre@example.com" first-name="Sarah" last-name="McIntyre" password="$argon2id$v=19$m=65536,t=3,p=4$U2FsdGVkc3M$08SY0x7DUPwTV12ZckHdNg" address1="1234 Address St" city="Austin" state="Texas" zipcode="12345" country="US" county="Travis" phone="123-456-789" title="Designer" bio="This is my bio" created="2026-02-01 09:00:00+00" updated-at="2026-02-01 09:00:00+00"></member->
<member- id="7" email="marcus.webb@example.com" first-name="Marcus" last-name="Webb" password="$argon2id$v=19$m=65536,t=3,p=4$ioAYDPtyUulykMrH9W7q9A$lG43cq6Dj3/n1+bJrkupWpB5Xro3UIQaVd9rjuJJ6nM" address1="1234 Address St" city="Austin" state="Texas" zipcode="12345" country="US" county="Travis" phone="123-456-789" title="Engineer" bio="This is my bio" created="2026-02-01 09:00:00+00" updated-at="2026-02-01 09:00:00+00"></member->
<member- id="8" email="priya.anand@example.com" first-name="Priya" last-name="Anand" password="$argon2id$v=19$m=65536,t=3,p=4$ioAYDPtyUulykMrH9W7q9A$lG43cq6Dj3/n1+bJrkupWpB5Xro3UIQaVd9rjuJJ6nM" address1="1234 Address St" city="Austin" state="Texas" zipcode="12345" country="US" county="Travis" phone="123-456-789" title="PM" bio="This is my bio" created="2026-02-01 09:00:00+00" updated-at="2026-02-01 09:00:00+00"></member->
<member- id="9" email="jordan.kim@example.com" first-name="Jordan" last-name="Kim" password="$argon2id$v=19$m=65536,t=3,p=4$ioAYDPtyUulykMrH9W7q9A$lG43cq6Dj3/n1+bJrkupWpB5Xro3UIQaVd9rjuJJ6nM" address1="1234 Address St" city="Austin" state="Texas" zipcode="12345" country="US" county="Travis" phone="123-456-789" title="Designer" bio="This is my bio" created="2026-02-01 09:00:00+00" updated-at="2026-02-01 09:00:00+00"></member->
<app- id="1" name="settings"></app->
<app- id="2" name="people"></app->
<app- id="3" name="calendar"></app->
<app- id="4" name="treasury"></app->
<app- id="5" name="politics"></app->
<app- id="6" name="files"></app->
<app- id="7" name="jobs"></app->
<app- id="8" name="tasks"></app->
<app- id="9" name="chat"></app->
<app- id="10" name="announcements"></app->
<permission- id="1" key="events.add" app-id="3" description="Can add events"></permission->
<permission- id="2" key="events.delete" app-id="3" description="Can delete events"></permission->
<permission- id="3" key="events.edit" app-id="3" description="Can edit events"></permission->
<permission- id="4" key="events.get" app-id="3" description="Can view events"></permission->
<permission- id="5" key="jobs.add" app-id="7" description="Can add jobs"></permission->
<permission- id="6" key="jobs.delete" app-id="7" description="Can delete jobs"></permission->
<permission- id="7" key="jobs.edit" app-id="7" description="Can edit jobs"></permission->
<permission- id="8" key="jobs.get" app-id="7" description="Can view jobs"></permission->
<permission- id="9" key="announcements.add" app-id="10" description="Can add announcements"></permission->
<permission- id="10" key="announcements.delete" app-id="10" description="Can delete announcements"></permission->
<permission- id="11" key="announcements.edit" app-id="10" description="Can edit announcements"></permission->
<permission- id="12" key="announcements.get" app-id="10" description="Can view announcements"></permission->
<permission- id="13" key="role_apps.edit" app-id="1" description="Can edit role apps"></permission->
<permission- id="14" key="roles.create" app-id="1" description="Can create roles"></permission->
<permission- id="15" key="roles.delete" app-id="1" description="Can delete roles"></permission->
<permission- id="16" key="role_notifications.edit" app-id="1" description="Can edit role notifications"></permission->
<permission- id="17" key="chats.create" app-id="9" description="Can create chats"></permission->
<permission- id="18" key="chats.edit" app-id="9" description="Can edit chats"></permission->
<permission- id="19" key="chats.delete" app-id="9" description="Can delete chats"></permission->
<permission- id="20" key="chats_message.send" app-id="9" description="Can send messages"></permission->
<permission- id="21" key="chats_message.edit" app-id="9" description="Can edit messages"></permission->
<permission- id="22" key="chats_message.delete" app-id="9" description="Can delete messages"></permission->
<member-app- id="1" member-id="1" app-id="1"></member-app->
<member-app- id="2" member-id="4" app-id="1"></member-app->
<member-app- id="3" member-id="6" app-id="1"></member-app->
<member-app- id="4" member-id="1" app-id="2"></member-app->
<member-app- id="5" member-id="4" app-id="2"></member-app->
<member-app- id="6" member-id="6" app-id="2"></member-app->
<member-app- id="7" member-id="1" app-id="3"></member-app->
<member-app- id="8" member-id="4" app-id="3"></member-app->
<member-app- id="9" member-id="6" app-id="3"></member-app->
<member-app- id="10" member-id="1" app-id="4"></member-app->
<member-app- id="11" member-id="4" app-id="4"></member-app->
<member-app- id="12" member-id="6" app-id="4"></member-app->
<member-app- id="13" member-id="1" app-id="5"></member-app->
<member-app- id="14" member-id="4" app-id="5"></member-app->
<member-app- id="15" member-id="6" app-id="5"></member-app->
<member-app- id="16" member-id="1" app-id="6"></member-app->
<member-app- id="17" member-id="4" app-id="6"></member-app->
<member-app- id="18" member-id="6" app-id="6"></member-app->
<member-app- id="19" member-id="1" app-id="7"></member-app->
<member-app- id="20" member-id="4" app-id="7"></member-app->
<member-app- id="21" member-id="6" app-id="7"></member-app->
<member-app- id="22" member-id="1" app-id="8"></member-app->
<member-app- id="23" member-id="4" app-id="8"></member-app->
<member-app- id="24" member-id="6" app-id="8"></member-app->
<member-app- id="25" member-id="1" app-id="9"></member-app->
<member-app- id="26" member-id="4" app-id="10"></member-app->
<member-app- id="27" member-id="6" app-id="9"></member-app->
<!-- network: cs -->
<!-- network 1: Captured Sun -->
<network- id="1" name="Captured Sun" logo="cs.svg" abbreviation="cs" stripe-account-id="acct_1Sn6DwLpyskwAml9" created="2026-01-10 09:58:01.0074"></network->
<network-plan- id="1" network-id="1" stripe-price-id="price_1T3uaxLpyskwAml9p0r0nh2h" name="Patron Membership" price="200.00" description="Members 40+" active="true" created="2026-03-29 22:14:45.414163"></network-plan->
<network-plan- id="2" network-id="1" stripe-price-id="price_1T3uaQLpyskwAml9rZAKBcy0" name="Regular Membership" price="100.00" description="Members 18-40" active="true" created="2026-03-29 22:14:45.414163"></network-plan->
<join-code- id="1" code="cs" network-id="1"></join-code->
<member-network- id="1" member-id="1" network-id="1" created="2025-11-24 00:54:36.0784"></member-network->
<member-network- id="2" member-id="2" network-id="1" created="2026-01-13 13:14:28.0178"></member-network->
<member-network- id="3" member-id="3" network-id="1" created="2026-01-13 13:28:35.0701"></member-network->
<role- id="1" network-id="1" name="admin" is-default="false"></role->
<role- id="2" network-id="1" name="member" is-default="true"></role->
<role-app- id="1" role-id="1" app-id="1" network-id="1"></role-app->
<role-app- id="2" role-id="1" app-id="2" network-id="1"></role-app->
<role-app- id="3" role-id="1" app-id="3" network-id="1"></role-app->
<role-app- id="4" role-id="1" app-id="4" network-id="1"></role-app->
<role-app- id="5" role-id="1" app-id="5" network-id="1"></role-app->
<role-app- id="6" role-id="1" app-id="6" network-id="1"></role-app->
<role-app- id="7" role-id="1" app-id="7" network-id="1"></role-app->
<role-app- id="8" role-id="1" app-id="8" network-id="1"></role-app->
<role-app- id="9" role-id="1" app-id="9" network-id="1"></role-app->
<role-app- id="10" role-id="1" app-id="10" network-id="1"></role-app->
<role-permission- id="1" role-id="1" permission-key="events.get" network-id="1"></role-permission->
<role-permission- id="2" role-id="1" permission-key="jobs.get" network-id="1"></role-permission->
<role-permission- id="3" role-id="1" permission-key="announcements.get" network-id="1"></role-permission->
<role-permission- id="4" role-id="1" permission-key="events.add" network-id="1"></role-permission->
<role-permission- id="5" role-id="1" permission-key="events.delete" network-id="1"></role-permission->
<role-permission- id="6" role-id="1" permission-key="events.edit" network-id="1"></role-permission->
<role-permission- id="7" role-id="1" permission-key="jobs.add" network-id="1"></role-permission->
<role-permission- id="8" role-id="1" permission-key="jobs.delete" network-id="1"></role-permission->
<role-permission- id="9" role-id="1" permission-key="jobs.edit" network-id="1"></role-permission->
<role-permission- id="10" role-id="1" permission-key="announcements.add" network-id="1"></role-permission->
<role-permission- id="11" role-id="1" permission-key="announcements.delete" network-id="1"></role-permission->
<role-permission- id="12" role-id="1" permission-key="announcements.edit" network-id="1"></role-permission->
<role-permission- id="13" role-id="1" permission-key="role_apps.edit" network-id="1"></role-permission->
<role-permission- id="14" role-id="1" permission-key="roles.create" network-id="1"></role-permission->
<role-permission- id="15" role-id="1" permission-key="roles.delete" network-id="1"></role-permission->
<role-permission- id="16" role-id="1" permission-key="chats.create" network-id="1"></role-permission->
<role-permission- id="17" role-id="1" permission-key="chats.edit" network-id="1"></role-permission->
<role-permission- id="18" role-id="1" permission-key="chats.delete" network-id="1"></role-permission->
<role-permission- id="19" role-id="1" permission-key="chats_message.send" network-id="1"></role-permission->
<role-permission- id="20" role-id="1" permission-key="chats_message.edit" network-id="1"></role-permission->
<role-permission- id="21" role-id="1" permission-key="chats_message.delete" network-id="1"></role-permission->
<role-permission- id="22" role-id="1" permission-key="role_notifications.edit" network-id="1"></role-permission->
<role-permission- id="23" role-id="2" permission-key="events.get" network-id="1"></role-permission->
<role-permission- id="24" role-id="2" permission-key="jobs.get" network-id="1"></role-permission->
<role-permission- id="25" role-id="2" permission-key="announcements.get" network-id="1"></role-permission->
<role-permission- id="26" role-id="2" permission-key="events.add" network-id="1"></role-permission->
<role-permission- id="27" role-id="2" permission-key="chats.create" network-id="1"></role-permission->
<role-permission- id="28" role-id="2" permission-key="chats_message.send" network-id="1"></role-permission->
<member-role- id="1" member-id="1" role-id="1" granted-by="1" network-id="1"></member-role->
<member-role- id="2" member-id="2" role-id="2" granted-by="1" network-id="1"></member-role->
<member-role- id="3" member-id="3" role-id="2" granted-by="1" network-id="1"></member-role->
<join-form- schema="org_1" id="1" fname="James" lname="Mitchell" email="james.mitchell@gmail.com" phone="512-555-0101" county="Comal" time="2025-12-16 23:11:31.0011" network-id="1"></join-form->
<join-form- schema="org_1" id="2" fname="Rachel" lname="Torres" email="rachel.torres@yahoo.com" phone="512-555-0102" county="Bexar" time="2025-12-19 19:23:12.0717" network-id="1"></join-form->
<join-form- schema="org_1" id="3" fname="David" lname="Nguyen" email="david.nguyen@gmail.com" phone="830-555-0103" county="Comal" time="2026-01-06 16:55:29.0288" network-id="1"></join-form->
<join-form- schema="org_1" id="4" fname="Emily" lname="Sanders" email="emily.sanders@outlook.com" phone="210-555-0104" county="Hays" time="2026-01-07 17:14:01.0711" network-id="1"></join-form->
<contact-form- schema="org_1" id="1" fname="Marcus" lname="Webb" email="marcus.webb@gmail.com" phone="512-555-0201" county="Comal" message="Interested in volunteering at upcoming events." time="2025-12-29 13:20:28.0157" network-id="1"></contact-form->
<contact-form- schema="org_1" id="2" fname="Sandra" lname="Holloway" email="sandra.holloway@gmail.com" phone="830-555-0202" county="Comal" message="Would love to connect with your organization." time="2025-12-30 22:10:24.0971" network-id="1"></contact-form->
<contact-form- schema="org_1" id="3" fname="Robert" lname="Finley" email="robert.finley@gmail.com" phone="210-555-0203" county="Comal" message="Looking forward to getting more involved locally." time="2026-01-10 21:23:51.0073" network-id="1"></contact-form->
<contact-form- schema="org_1" id="4" fname="Barbara" lname="Crane" email="barbara.crane@outlook.com" phone="512-555-0204" county="Comal" message="Please reach out regarding the next meeting schedule." time="2026-01-10 21:23:54.0841" network-id="1"></contact-form->
</forms->

Binary file not shown.

View File

@@ -0,0 +1,93 @@
Copyright (c) 2010, Igino Marini (mail@iginomarini.com)
This Font Software is licensed under the SIL Open Font License, Version 1.1.
This license is copied below, and is also available with a FAQ at:
https://openfontlicense.org
-----------------------------------------------------------
SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
-----------------------------------------------------------
PREAMBLE
The goals of the Open Font License (OFL) are to stimulate worldwide
development of collaborative font projects, to support the font creation
efforts of academic and linguistic communities, and to provide a free and
open framework in which fonts may be shared and improved in partnership
with others.
The OFL allows the licensed fonts to be used, studied, modified and
redistributed freely as long as they are not sold by themselves. The
fonts, including any derivative works, can be bundled, embedded,
redistributed and/or sold with any software provided that any reserved
names are not used by derivative works. The fonts and derivatives,
however, cannot be released under any other type of license. The
requirement for fonts to remain under this license does not apply
to any document created using the fonts or their derivatives.
DEFINITIONS
"Font Software" refers to the set of files released by the Copyright
Holder(s) under this license and clearly marked as such. This may
include source files, build scripts and documentation.
"Reserved Font Name" refers to any names specified as such after the
copyright statement(s).
"Original Version" refers to the collection of Font Software components as
distributed by the Copyright Holder(s).
"Modified Version" refers to any derivative made by adding to, deleting,
or substituting -- in part or in whole -- any of the components of the
Original Version, by changing formats or by porting the Font Software to a
new environment.
"Author" refers to any designer, engineer, programmer, technical
writer or other person who contributed to the Font Software.
PERMISSION & CONDITIONS
Permission is hereby granted, free of charge, to any person obtaining
a copy of the Font Software, to use, study, copy, merge, embed, modify,
redistribute, and sell modified and unmodified copies of the Font
Software, subject to the following conditions:
1) Neither the Font Software nor any of its individual components,
in Original or Modified Versions, may be sold by itself.
2) Original or Modified Versions of the Font Software may be bundled,
redistributed and/or sold with any software, provided that each copy
contains the above copyright notice and this license. These can be
included either as stand-alone text files, human-readable headers or
in the appropriate machine-readable metadata fields within text or
binary files as long as those fields can be easily viewed by the user.
3) No Modified Version of the Font Software may use the Reserved Font
Name(s) unless explicit written permission is granted by the corresponding
Copyright Holder. This restriction only applies to the primary font name as
presented to the users.
4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
Software shall not be used to promote, endorse or advertise any
Modified Version, except to acknowledge the contribution(s) of the
Copyright Holder(s) and the Author(s) or with their explicit written
permission.
5) The Font Software, modified or unmodified, in part or in whole,
must be distributed entirely under this license, and must not be
distributed under any other license. The requirement for fonts to
remain under this license does not apply to any document created
using the Font Software.
TERMINATION
This license becomes null and void if any of the above conditions are
not met.
DISCLAIMER
THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
OTHER DEALINGS IN THE FONT SOFTWARE.

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.1 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.1 MiB

View File

@@ -0,0 +1,29 @@
<svg width="534" height="534" viewBox="0 0 534 534" fill="none" xmlns="http://www.w3.org/2000/svg">
<rect width="9" height="534" fill="black"/>
<rect x="21" width="9" height="534" fill="black"/>
<rect x="42" width="9" height="534" fill="black"/>
<rect x="63" width="9" height="534" fill="black"/>
<rect x="84" width="9" height="534" fill="black"/>
<rect x="105" width="9" height="534" fill="black"/>
<rect x="126" width="9" height="534" fill="black"/>
<rect x="147" width="9" height="534" fill="black"/>
<rect x="168" width="9" height="534" fill="black"/>
<rect x="189" width="9" height="534" fill="black"/>
<rect x="210" width="9" height="534" fill="black"/>
<rect x="231" width="9" height="534" fill="black"/>
<circle cx="266.5" cy="271.5" r="127.5" fill="#FF0000"/>
<rect x="273" width="9" height="534" fill="black"/>
<rect x="294" width="9" height="534" fill="black"/>
<rect x="315" width="9" height="534" fill="black"/>
<rect x="336" width="9" height="534" fill="black"/>
<rect x="357" width="9" height="534" fill="black"/>
<rect x="378" width="9" height="534" fill="black"/>
<rect x="399" width="9" height="534" fill="black"/>
<rect x="420" width="9" height="534" fill="black"/>
<rect x="441" width="9" height="534" fill="black"/>
<rect x="462" width="9" height="534" fill="black"/>
<rect x="483" width="9" height="534" fill="black"/>
<rect x="504" width="9" height="534" fill="black"/>
<rect x="525" width="9" height="534" fill="black"/>
<rect x="252" width="9" height="534" fill="black"/>
</svg>

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.1 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 767 KiB

View File

@@ -0,0 +1,460 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover">
<title>Captured Sun</title>
<link rel="icon" href="/_/logo.svg">
<style>
@font-face {
font-family: 'IMFell';
src: url('/_/IMFell/IMFell.ttf') format('truetype');
font-weight: normal;
font-style: normal;
}
*, *::before, *::after { box-sizing: border-box; }
body {
overflow: hidden;
margin: 0;
padding: 0;
background: #000;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif; }
img {
user-select: none;
-webkit-user-drag: none;
pointer-events: none;
}
a:visited {
color: inherit;
}
@keyframes rotate-stars {
0% { transform: rotate(0deg) translateX(0); }
25% { transform: rotate(90deg) translateX(50px); }
50% { transform: rotate(180deg) translateX(0); }
75% { transform: rotate(270deg) translateX(-50px); }
100% { transform: rotate(360deg) translateX(0); }
}
.stars {
display: block;
height: auto;
position: absolute;
animation: rotate-stars 950s linear infinite;
transform-origin: center center;
top: -550px;
width: 1600px;
z-index: 0;
}
.moon {
position: fixed;
z-index: 2;
width: 100vw;
left: 0px;
bottom: 0px; /* seam overlap — tweak to taste */
}
.atlas {
position: fixed;
left: 50%;
bottom: -100px;
transform: translateX(-50%);
width: 85vw;
height: auto;
z-index: 3;
pointer-events: none;
}
.atlas img { display: block; width: 100%; height: auto; }
.nav {
position: fixed;
bottom: 440px; left: 0; right: 0;
display: flex; justify-content: center; gap: 18px;
z-index: 4;
}
.btn {
padding: 12px 20px;
border-radius: 11px;
font-size: 16px;
font-weight: 600;
letter-spacing: 0.02em;
cursor: pointer;
font-family: 'IMFell';
backdrop-filter: blur(14px) saturate(160%);
-webkit-backdrop-filter: blur(14px) saturate(160%);
box-shadow:
inset 0 0.5px 0 rgba(255, 255, 255, 0.35),
inset 0 -1px 0 rgba(255, 255, 255, 0.08),
0 8px 24px rgba(0, 0, 0, 0.25);
transition: transform 120ms ease, box-shadow 120ms ease;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn-red {
background: rgba(220, 38, 38, 0.30);
color: #d06868;
border: 0.5px solid rgba(254, 202, 202, 0.05);
}
.btn-orange {
background: rgba(234, 88, 12, 0.30);
color: #d79d5a;
border: 0.5px solid rgba(254, 215, 170, 0.05);
}
.btn-yellow {
background: rgba(234, 179, 8, 0.30);
color: #d0c04b;
border: 0.5px solid rgba(254, 240, 138, 0.05);
}
.menu {
position: fixed;
border-radius: 11px;
overflow: hidden;
z-index: 10;
backdrop-filter: blur(14px) saturate(160%);
-webkit-backdrop-filter: blur(14px) saturate(160%);
box-shadow:
inset 0 0.5px 0 rgba(255, 255, 255, 0.35),
inset 0 -1px 0 rgba(255, 255, 255, 0.08),
0 8px 24px rgba(0, 0, 0, 0.25);
transition:
top 460ms cubic-bezier(0.32, 0.72, 0.20, 1),
left 460ms cubic-bezier(0.32, 0.72, 0.20, 1),
width 460ms cubic-bezier(0.32, 0.72, 0.20, 1),
height 460ms cubic-bezier(0.32, 0.72, 0.20, 1),
border-radius 460ms cubic-bezier(0.32, 0.72, 0.20, 1);
visibility: hidden;
pointer-events: none;
font-family: 'IMFell';
}
.menu.is-active { visibility: visible; pointer-events: auto; }
.menu-red { background: rgba(220, 38, 38, 0.30); color: #fab2b2; border: 0.5px solid rgba(254, 202, 202, 0.05); }
.menu-orange { background: rgba(234, 88, 12, 0.30); color: #d79d5a; border: 0.5px solid rgba(254, 215, 170, 0.05); }
.menu-yellow { background: rgba(234, 179, 8, 0.30); color: #d0c04b; border: 0.5px solid rgba(254, 240, 138, 0.05); }
.menu-close {
position: absolute;
top: 18px; right: 18px;
width: 36px; height: 36px;
border-radius: 50%;
border: 0.5px solid rgba(255, 255, 255, 0.10);
background: rgba(0, 0, 0, 0.20);
color: inherit;
font-size: 22px;
line-height: 1;
cursor: pointer;
display: flex; align-items: center; justify-content: center;
opacity: 0;
transition: opacity 180ms ease, background 150ms ease;
z-index: 2;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
}
.menu-close:hover { background: rgba(0, 0, 0, 0.35); }
.menu.is-open .menu-close { opacity: 1; }
.menu-inner {
padding: 72px 56px 56px;
opacity: 0;
transform: translateY(8px);
transition: opacity 220ms ease, transform 220ms ease;
height: 100%;
overflow-y: auto;
color: inherit;
}
.menu.is-open .menu-inner {
opacity: 1;
transform: translateY(0);
transition-delay: 280ms;
}
.menu h2 {
margin: 0 0 24px;
font-size: 36px;
font-weight: 400;
letter-spacing: 0.02em;
}
.menu p {
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
font-size: 16px;
line-height: 1.65;
margin: 0 0 16px;
max-width: 62ch;
}
.link-list {
list-style: none;
padding: 0;
margin: 0;
display: grid;
grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
gap: 12px;
}
.link-list a {
display: block;
padding: 16px 18px;
background: rgba(0, 0, 0, 0.15);
border: 0.5px solid rgba(255, 255, 255, 0.06);
border-radius: 10px;
color: inherit;
text-decoration: none;
transition: background 150ms ease, transform 150ms ease;
}
.link-list a:hover { background: rgba(0, 0, 0, 0.30); transform: translateY(-1px); }
.link-list .label { display: block; font-size: 17px; }
.link-list .desc {
display: block;
font-size: 13px;
opacity: 0.7;
margin-top: 4px;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
}
.contact-form {
display: grid;
gap: 16px;
max-width: 560px;
}
.contact-form label {
display: grid;
gap: 6px;
font-size: 13px;
letter-spacing: 0.08em;
text-transform: uppercase;
opacity: 0.85;
}
.contact-form input,
.contact-form textarea {
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
font-size: 15px;
color: #f0e6c8;
padding: 12px 14px;
background: rgba(0, 0, 0, 0.50);
border: 0.5px solid rgba(255, 255, 255, 0.08);
border-radius: 8px;
outline: none;
transition: border-color 150ms ease, background 150ms ease;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder { color: rgba(240, 230, 200, 0.35); }
.contact-form input:focus,
.contact-form textarea:focus {
border-color: rgba(255, 255, 255, 0.25);
background: rgba(0, 0, 0, 0.65);
}
.contact-form textarea { resize: vertical; min-height: 140px; }
.contact-form .submit {
justify-self: end;
margin-top: 4px;
padding: 12px 26px;
border-radius: 10px;
border: 0.5px solid rgba(254, 240, 138, 0.10);
background: rgba(234, 179, 8, 0.40);
color: inherit;
font-family: 'IMFell';
font-size: 16px;
letter-spacing: 0.04em;
cursor: pointer;
transition: transform 120ms ease, background 120ms ease;
}
.contact-form .submit:hover { background: rgba(234, 179, 8, 0.55); transform: translateY(-1px); }
@media (max-width: 768px) {
.space {
position: absolute;
transform: translate(-50%, 0);
top: 0px;
display:none;
width: 1200px;
}
.moon {
display: none;
}
.stars {
display: none;
}
.atlas {
top: -200px;
width: 1000px;
}
.nav {
bottom: 1vh
}
.menu-red {
color: rgb(255, 255, 255) !important
}
.menu-inner { padding: 64px 28px 28px; }
.menu h2 { font-size: 28px; }
}
</style>
</head>
<body style="cursor: default">
<img class="stars" src="/_/stars.png" alt="">
<img class="moon" src="/_/moon.png" alt="">
<picture class="atlas">
<source media="(max-width: 768px)" srcset="/_/atlasmobile.png">
<img src="/_/atlas.webp" alt="">
</picture>
<nav class="nav">
<button class="btn btn-red">About</button>
<!-- <button class="btn btn-orange">Our Work</button> -->
<button class="btn btn-orange">Contact Us</button>
</nav>
<div class="menu menu-red" id="menu-about">
<button class="menu-close" aria-label="Close">X</button>
<div class="menu-inner">
<h2>About</h2>
<p><i>All energy comes from the sun. To think is to capture, freeze, and reflect it.</i></p>
<p>Captured Sun was founded in 2022, to answer a simple question: what would the operating system look like if it was rearranged for the modern day?</p>
<p>The answer we have found is <a style="color: inherit;" href="https://frm.so" target="_blank">Forum</a>: the Community Operating System.</p>
<p>In concert with Forum, we are happy to accept certain consulting jobs with people or organizations that need custom solutions. If that's you, feel free to reach out.</p>
</div>
</div>
<div class="menu menu-orange" id="menu-work">
<button class="menu-close" aria-label="Close">X</button>
<div class="menu-inner">
<h2>Our Work</h2>
<ul class="link-list">
<li><a href="https://apple.com" target="_blank" rel="noopener"><span class="label">Apple</span><span class="desc">Product launch microsite</span></a></li>
<li><a href="https://vercel.com" target="_blank" rel="noopener"><span class="label">Vercel</span><span class="desc">Edge runtime documentation</span></a></li>
<li><a href="https://linear.app" target="_blank" rel="noopener"><span class="label">Linear</span><span class="desc">Marketing site redesign</span></a></li>
<li><a href="https://figma.com" target="_blank" rel="noopener"><span class="label">Figma</span><span class="desc">Plugin gallery</span></a></li>
<li><a href="https://stripe.com" target="_blank" rel="noopener"><span class="label">Stripe</span><span class="desc">Developer onboarding flow</span></a></li>
<li><a href="https://railway.com" target="_blank" rel="noopener"><span class="label">Railway</span><span class="desc">Pricing page experiments</span></a></li>
<li><a href="https://anthropic.com" target="_blank" rel="noopener"><span class="label">Anthropic</span><span class="desc">Research publication template</span></a></li>
<li><a href="https://notion.so" target="_blank" rel="noopener"><span class="label">Notion</span><span class="desc">Template marketplace</span></a></li>
</ul>
</div>
</div>
<div class="menu menu-orange" id="menu-contact">
<button class="menu-close" aria-label="Close"><span>X</span></button>
<div class="menu-inner">
<h2>Contact Us</h2>
<form class="contact-form" novalidate onsubmit="return handleContactSubmit(event, this)">
<label>Name <input type="text" name="name" placeholder="Your name" required></label>
<label>Email <input type="email" name="email" placeholder="you@example.com"></label>
<label>Phone <input type="tel" name="phone" placeholder="+1 555 123 4567"></label>
<label>Message <textarea name="message" placeholder="Tell us about your project..." required></textarea></label>
<button class="submit" type="submit">Send Message</button>
</form>
</div>
</div>
<script>
function handleContactSubmit(event, form) {
event.preventDefault();
var email = form.email.value.trim();
var phone = form.phone.value.trim();
if (!email && !phone) {
form.email.setCustomValidity('Provide an email or a phone number.');
form.email.reportValidity();
return false;
}
form.email.setCustomValidity('');
if (!form.checkValidity()) { form.reportValidity(); return false; }
form.reset();
return false;
}
(function () {
var pairs = [
{ btn: document.querySelector('.btn-red'), menu: document.getElementById('menu-about') },
{ btn: document.querySelector('.btn-orange'), menu: document.getElementById('menu-contact') }
];
var active = null;
var FINAL_RADIUS = '18px';
function applyRect(menu, rect) {
menu.style.top = rect.top + 'px';
menu.style.left = rect.left + 'px';
menu.style.width = rect.width + 'px';
menu.style.height = rect.height + 'px';
menu.style.borderRadius = '11px';
}
function applyFinal(menu) {
menu.style.top = '10vh';
menu.style.left = '10vw';
menu.style.width = '80vw';
menu.style.height = '80vh';
menu.style.borderRadius = FINAL_RADIUS;
}
function openMenu(pair) {
if (active) closeMenu();
var btn = pair.btn, menu = pair.menu;
if (menu._closeTimer) { clearTimeout(menu._closeTimer); menu._closeTimer = null; }
var rect = btn.getBoundingClientRect();
menu.style.transition = 'none';
applyRect(menu, rect);
menu.classList.add('is-active');
void menu.offsetHeight;
menu.style.transition = '';
btn.style.visibility = 'hidden';
applyFinal(menu);
menu.classList.add('is-open');
active = pair;
}
function closeMenu() {
if (!active) return;
var btn = active.btn, menu = active.menu;
var rect = btn.getBoundingClientRect();
applyRect(menu, rect);
menu.classList.remove('is-open');
if (menu._closeTimer) clearTimeout(menu._closeTimer);
menu._closeTimer = setTimeout(function () {
menu.classList.remove('is-active');
btn.style.visibility = '';
menu._closeTimer = null;
}, 460);
active = null;
}
pairs.forEach(function (pair) {
pair.btn.addEventListener('click', function (e) {
e.stopPropagation();
openMenu(pair);
});
pair.menu.addEventListener('click', function (e) { e.stopPropagation(); });
pair.menu.querySelector('.menu-close').addEventListener('click', function (e) {
e.stopPropagation();
closeMenu();
});
});
document.addEventListener('click', function () {
if (active) closeMenu();
});
window.addEventListener('keydown', function (e) {
if (e.key === 'Escape' && active) closeMenu();
});
window.addEventListener('resize', function () {
if (!active) return;
applyFinal(active.menu);
});
})();
</script>
</body>
</html>