diff --git a/src/components/ability.webc b/src/components/ability.webc index 3f15853..5ce6716 100644 --- a/src/components/ability.webc +++ b/src/components/ability.webc @@ -6,8 +6,13 @@ :alt="`${$data.firstName.toLowerCase()}'s ${name}`" :width="[250, 500]" sizes="(min-width: 64em) 500px, 250px" - >Here you would see an illustration… If I had one… + > + + Here you would see an illustration… If I had one…

@@ -16,18 +21,23 @@ diff --git a/src/components/page-content.webc b/src/components/page-content.webc index 686471c..3b2fc5b 100644 --- a/src/components/page-content.webc +++ b/src/components/page-content.webc @@ -1,5 +1,5 @@
- +
diff --git a/src/components/page-footer.webc b/src/components/page-footer.webc new file mode 100644 index 0000000..8968d70 --- /dev/null +++ b/src/components/page-footer.webc @@ -0,0 +1,61 @@ + + + + + diff --git a/src/components/ref-img.webc b/src/components/ref-img.webc index 640b6f4..fcc7dca 100644 --- a/src/components/ref-img.webc +++ b/src/components/ref-img.webc @@ -56,11 +56,15 @@ :host :where(picture, img) { grid-area: image; + display: grid; + grid-template-columns: subgrid; + justify-items: center; + max-width: 100%; } :host .image { display: block; - width: 100%; + width: auto; height: 100%; max-height: 35rem; object-fit: contain; @@ -72,7 +76,7 @@ } :host .dropshadow { - filter: drop-shadow(0.5em 0.25em 0.375em oklch(0 0 0 / 0.5)); + filter: drop-shadow(0.5em 0.25em 0.375em var(--clr-box-shadow)); } :host .caption { diff --git a/src/layouts/base.webc b/src/layouts/base.webc index 31328a3..d059c16 100644 --- a/src/layouts/base.webc +++ b/src/layouts/base.webc @@ -14,5 +14,8 @@ - + + + + diff --git a/src/layouts/character.webc b/src/layouts/character.webc index 7932c32..1744f36 100644 --- a/src/layouts/character.webc +++ b/src/layouts/character.webc @@ -1,6 +1,5 @@ --- layout: base.webc -feedbackLink: https://cloud.sebin-nyshkim.net/apps/forms/s/eHjsosE9FB4fCpjBt4mbPfje --- @@ -32,16 +31,7 @@ feedbackLink: https://cloud.sebin-nyshkim.net/apps/forms/s/eHjsosE9FB4fCpjBt4mbP - + diff --git a/src/privacy.md b/src/privacy.md new file mode 100644 index 0000000..b704714 --- /dev/null +++ b/src/privacy.md @@ -0,0 +1,45 @@ +--- +layout: 'page.webc' +title: Privacy Policy +--- + +I use a self-hosted [Ackee](https://ackee.electerious.com) instance to gain insights about the types of devices that visit this site. + +Ackee is open-source analytics software. The data it collects is anonymized in a way that does not allow me to identify individual visitors. It also does not save any cookies and does not follow you around the web. I merely store whether you agree to analytics collection or not in your browser's local storage. + +## Data that Ackee collects + +Ackee gives me insight into the following data points: + +* Number of visits per day +* Number of visitors that currently view the site +* Approximate duration of stay +* Number of times a given page was visited +* Sites a visit originated from (referrer) +* Name and manufacturer of the device +* Name and version of the operating system +* Name and version of the browser +* Screen size of the device +* Primary language of the browser or operating system + +Ackee uses the IP, user-agent and domainId to identify a user. All information will be hashed together with a [salt](https://en.wikipedia.org/wiki/Salt_(cryptography)) that changes daily. The final hash is called `clientId`. + +The daily salt is never stored anywhere. It avoids that database backups can be used to stick data together to reconstruct the browsing history of a user. + +## Purpose of collecting data + +I collect this data to better understand my audience, improve the site's user experience, and to inform future development and editorial decisions. The data will not be shared with anyone, ever. + +## Data retention + +Ackee removes data from previous records when a new record with an existing identification gets added. This way the user identifier and other identifiable data is only stored once in the database. + +In other words: Ackee forgets who you are as soon as it sees you again. It's not possible to reconstruct a browsing history, even on a daily basis. + +## User consent + +Data collection is opt-in. I will not collect any analytics data until you explicitly allow me to do so. If you previously opted-in but changed your mind, click the button below: + + + +By using this site, you acknowledge that you have read and understood this privacy policy. If you have any questions or concerns about how your data is collected or used, please feel free to [contact me](https://sebin-nyshkim.net/contact). diff --git a/src/sebin/abilities.md b/src/sebin/abilities.md index 9d89c6d..9030bc5 100644 --- a/src/sebin/abilities.md +++ b/src/sebin/abilities.md @@ -8,18 +8,18 @@ As a fire dragon, Sebin possesses a myriad of abilities that he can unleash upon ## Attacks - + The signature move of any fire dragon. Special glands in his mouth together with a deep, deliberate breath to enrich his lungs create a combustible cocktail. The resulting jet of fire upon exhaling is a torrent of several hundred degrees Celsius, scorching everything in its wake. - + When there isn't a direct line of sight between Sebin and his opponent, he can spit fire into his hands and shape it into a throwable projectile. His scales are naturally fireproof, allowing him to withstand the intense heat without flinching. Even if he misses his target, the resulting blast upon impact is enough to cause considerable damage alone—especially when he combines two projectiles to increase the explosion radius. - + Sebin's fists become instruments of destruction when he engulfs them in his flames. Targeted blows are capable of inflicting agonizing burns on his opponents. He can also release controlled blasts of fire from his fists, unleashing smoldering waves of heat to scorch and disorient his foes. - + This aerial attack is a masterpiece of Sebin's pyromancy skills. By engulfing himself in flames while spinning at breakneck speeds in mid-air, he creates a whirling vortex of fire that can singe even the most elusive opponents. Those who dare to face him in the skies will soon find themselves caught in the maelstrom of his most fearsome attack.