@charset "UTF-8";
/** Reset some basic elements */
body, h1, h2, h3, h4, h5, h6, p, blockquote, pre, hr, dl, dd, ol, ul, figure { margin: 0; padding: 0; }

/** Basic styling */
body { font: 400 16px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; color: #111; background-color: #fdfdfd; -webkit-text-size-adjust: 100%; -webkit-font-feature-settings: "kern" 1; -moz-font-feature-settings: "kern" 1; -o-font-feature-settings: "kern" 1; font-feature-settings: "kern" 1; font-kerning: normal; display: flex; min-height: 100vh; flex-direction: column; }

/** Set `margin-bottom` to maintain vertical rhythm */
h1, h2, h3, h4, h5, h6, p, blockquote, pre, ul, ol, dl, figure, .highlight { margin-bottom: 15px; }

/** `main` element */
main { display: block; /* Default value of `display` of `main` element is 'inline' in IE 11. */ }

/** Images */
img { max-width: 100%; vertical-align: middle; }

/** Figures */
figure > img { display: block; }

figcaption { font-size: 14px; }

/** Lists */
ul, ol { margin-left: 30px; }

li > ul, li > ol { margin-bottom: 0; }

/** Headings */
h1, h2, h3, h4, h5, h6 { font-weight: 400; }

/** Links */
a { color: #2a7ae2; text-decoration: none; }
a:visited { color: #1756a9; }
a:hover { color: #111; text-decoration: underline; }
.social-media-list a:hover { text-decoration: none; }
.social-media-list a:hover .username { text-decoration: underline; }

/** Blockquotes */
blockquote { color: #828282; border-left: 4px solid #e8e8e8; padding-left: 15px; font-size: 18px; letter-spacing: -1px; font-style: italic; }
blockquote > :last-child { margin-bottom: 0; }

/** Code formatting */
pre, code { font-size: 15px; border: 1px solid #e8e8e8; border-radius: 3px; background-color: #eef; }

code { padding: 1px 5px; }

pre { padding: 8px 12px; overflow-x: auto; }
pre > code { border: 0; padding-right: 0; padding-left: 0; }

/** Wrapper */
.wrapper { max-width: -webkit-calc(800px - (30px * 2)); max-width: calc(800px - (30px * 2)); margin-right: auto; margin-left: auto; padding-right: 30px; padding-left: 30px; }
@media screen and (max-width: 800px) { .wrapper { max-width: -webkit-calc(800px - (30px)); max-width: calc(800px - (30px)); padding-right: 15px; padding-left: 15px; } }

/** Clearfix */
.wrapper:after, .footer-col-wrapper:after { content: ""; display: table; clear: both; }

/** Icons */
.svg-icon { width: 16px; height: 16px; display: inline-block; fill: #828282; padding-right: 5px; vertical-align: text-top; }

.social-media-list li + li { padding-top: 5px; }

/** Tables */
table { margin-bottom: 30px; width: 100%; text-align: left; color: #3f3f3f; border-collapse: collapse; border: 1px solid #e8e8e8; }
table tr:nth-child(even) { background-color: #f7f7f7; }
table th, table td { padding: 10px 15px; }
table th { background-color: #f0f0f0; border: 1px solid #dedede; border-bottom-color: #c9c9c9; }
table td { border: 1px solid #e8e8e8; }

/** Site header */
.site-header { border-top: 5px solid #424242; border-bottom: 1px solid #e8e8e8; min-height: 55.95px; position: relative; }

.site-title { font-size: 26px; font-weight: 300; line-height: 54px; letter-spacing: -1px; margin-bottom: 0; float: left; }
.site-title, .site-title:visited { color: #424242; }

.site-nav { float: right; line-height: 54px; }
.site-nav .nav-trigger { display: none; }
.site-nav .menu-icon { display: none; }
.site-nav .page-link { color: #111; line-height: 1.5; }
.site-nav .page-link:not(:last-child) { margin-right: 20px; }
@media screen and (max-width: 600px) { .site-nav { position: absolute; top: 9px; right: 15px; background-color: #fdfdfd; border: 1px solid #e8e8e8; border-radius: 5px; text-align: right; }
  .site-nav label[for="nav-trigger"] { display: block; float: right; width: 36px; height: 36px; z-index: 2; cursor: pointer; }
  .site-nav .menu-icon { display: block; float: right; width: 36px; height: 26px; line-height: 0; padding-top: 10px; text-align: center; }
  .site-nav .menu-icon > svg { fill: #424242; }
  .site-nav input ~ .trigger { clear: both; display: none; }
  .site-nav input:checked ~ .trigger { display: block; padding-bottom: 5px; }
  .site-nav .page-link { display: block; padding: 5px 10px; margin-left: 20px; }
  .site-nav .page-link:not(:last-child) { margin-right: 0; } }

/** Site footer */
.site-footer { border-top: 1px solid #e8e8e8; padding: 30px 0; }

.footer-heading { font-size: 18px; margin-bottom: 15px; }

.contact-list, .social-media-list { list-style: none; margin-left: 0; }

.footer-col-wrapper { font-size: 15px; color: #828282; margin-left: -15px; }

.footer-col { float: left; margin-bottom: 15px; padding-left: 15px; }

.footer-col-1 { width: -webkit-calc(35% - (30px / 2)); width: calc(35% - (30px / 2)); }

.footer-col-2 { width: -webkit-calc(20% - (30px / 2)); width: calc(20% - (30px / 2)); }

.footer-col-3 { width: -webkit-calc(45% - (30px / 2)); width: calc(45% - (30px / 2)); }

@media screen and (max-width: 800px) { .footer-col-1, .footer-col-2 { width: -webkit-calc(50% - (30px / 2)); width: calc(50% - (30px / 2)); }
  .footer-col-3 { width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }
@media screen and (max-width: 600px) { .footer-col { float: none; width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }
/** Page content */
.page-content { padding: 30px 0; flex: 1; }

.page-heading { font-size: 32px; }

.post-list-heading { font-size: 28px; }

.post-list { margin-left: 0; list-style: none; }
.post-list > li { margin-bottom: 30px; }

.post-meta { font-size: 14px; color: #828282; }

.post-link { display: block; font-size: 24px; }

/** Posts */
.post-header { margin-bottom: 30px; }

.post-title { font-size: 42px; letter-spacing: -1px; line-height: 1; }
@media screen and (max-width: 800px) { .post-title { font-size: 36px; } }

.post-content { margin-bottom: 30px; }
.post-content h2 { font-size: 32px; }
@media screen and (max-width: 800px) { .post-content h2 { font-size: 28px; } }
.post-content h3 { font-size: 26px; }
@media screen and (max-width: 800px) { .post-content h3 { font-size: 22px; } }
.post-content h4 { font-size: 20px; }
@media screen and (max-width: 800px) { .post-content h4 { font-size: 18px; } }

/** Syntax highlighting styles */
.highlight { background: #fff; }
.highlighter-rouge .highlight { background: #eef; }
.highlight .c { color: #998; font-style: italic; }
.highlight .err { color: #a61717; background-color: #e3d2d2; }
.highlight .k { font-weight: bold; }
.highlight .o { font-weight: bold; }
.highlight .cm { color: #998; font-style: italic; }
.highlight .cp { color: #999; font-weight: bold; }
.highlight .c1 { color: #998; font-style: italic; }
.highlight .cs { color: #999; font-weight: bold; font-style: italic; }
.highlight .gd { color: #000; background-color: #fdd; }
.highlight .gd .x { color: #000; background-color: #faa; }
.highlight .ge { font-style: italic; }
.highlight .gr { color: #a00; }
.highlight .gh { color: #999; }
.highlight .gi { color: #000; background-color: #dfd; }
.highlight .gi .x { color: #000; background-color: #afa; }
.highlight .go { color: #888; }
.highlight .gp { color: #555; }
.highlight .gs { font-weight: bold; }
.highlight .gu { color: #aaa; }
.highlight .gt { color: #a00; }
.highlight .kc { font-weight: bold; }
.highlight .kd { font-weight: bold; }
.highlight .kp { font-weight: bold; }
.highlight .kr { font-weight: bold; }
.highlight .kt { color: #458; font-weight: bold; }
.highlight .m { color: #099; }
.highlight .s { color: #d14; }
.highlight .na { color: #008080; }
.highlight .nb { color: #0086B3; }
.highlight .nc { color: #458; font-weight: bold; }
.highlight .no { color: #008080; }
.highlight .ni { color: #800080; }
.highlight .ne { color: #900; font-weight: bold; }
.highlight .nf { color: #900; font-weight: bold; }
.highlight .nn { color: #555; }
.highlight .nt { color: #000080; }
.highlight .nv { color: #008080; }
.highlight .ow { font-weight: bold; }
.highlight .w { color: #bbb; }
.highlight .mf { color: #099; }
.highlight .mh { color: #099; }
.highlight .mi { color: #099; }
.highlight .mo { color: #099; }
.highlight .sb { color: #d14; }
.highlight .sc { color: #d14; }
.highlight .sd { color: #d14; }
.highlight .s2 { color: #d14; }
.highlight .se { color: #d14; }
.highlight .sh { color: #d14; }
.highlight .si { color: #d14; }
.highlight .sx { color: #d14; }
.highlight .sr { color: #009926; }
.highlight .s1 { color: #d14; }
.highlight .ss { color: #990073; }
.highlight .bp { color: #999; }
.highlight .vc { color: #008080; }
.highlight .vg { color: #008080; }
.highlight .vi { color: #008080; }
.highlight .il { color: #099; }

/* Purple/Femme Theme */
:root { --primary-purple: #9b59b6; --light-purple: #c39bd3; --dark-purple: #6c3483; --lavender: #e8daef; --pink: #f5a9b8; --soft-pink: #fce4ec; }

body { color: #2c1a3d; background-color: white; }

a { color: var(--primary-purple); }

a:hover { color: var(--dark-purple); }

.site-header { background-color: white; border-bottom: 1px solid #e0e0e0; }

.site-title, .site-title:visited { color: var(--primary-purple) !important; }

.site-nav .page-link { color: var(--primary-purple); }

.site-nav .page-link:hover { color: var(--dark-purple); }

h1, h2, h3, h4, h5, h6 { color: var(--primary-purple); }

.page-heading { text-align: center; }

.home .page-heading { text-align: center; }

strong { color: var(--primary-purple); }

hr { border-color: var(--light-purple); }

a:focus, button:focus { outline: 2px solid var(--primary-purple); outline-offset: 2px; }

.site-footer { background-color: white; border-top: 1px solid #e0e0e0; color: var(--dark-purple); }

.site-footer a { color: var(--primary-purple); }

.site-footer a:hover { color: var(--dark-purple); }

/* Style for resource sections */
.resource-section { background: #f8f9fa; padding: 1.5rem; border-radius: 8px; margin: 1rem 0; border-left: 4px solid #6c5ce7; }

.resource-section h3 { color: #6c5ce7; margin-top: 0; }

/* Warning/alert boxes */
.alert-box { background: #fff3cd; border: 1px solid #ffeaa7; border-radius: 4px; padding: 1rem; margin: 1rem 0; }

.alert-box.danger { background: #f8d7da; border-color: #f5c6cb; color: #721c24; }

.alert-box.info { background: #d1ecf1; border-color: #bee5eb; color: #0c5460; }

.alert-box.success { background: #d4edda; border-color: #c3e6cb; color: #155724; }

/* Pride colors for accents */
.pride-accent { background: linear-gradient(90deg, #e40303, #ff8c00, #ffed00, #008018, #004cff, #732982); height: 4px; width: 100%; margin: 1rem 0; }

/* Trans flag accent */
.trans-accent { background: linear-gradient(90deg, #5bcefa, #f5a9b8, #ffffff, #f5a9b8, #5bcefa); height: 4px; width: 100%; margin: 1rem 0; }

/* Responsive design improvements */
@media screen and (max-width: 768px) { .hero-section h1 { font-size: 2rem !important; }
  .hero-section p { font-size: 1rem !important; }
  .hero-section a { padding: 0.75rem 1.5rem !important; font-size: 1rem !important; } }
/* Accessibility improvements */
.high-contrast { filter: contrast(150%); }

/* Focus indicators */
a:focus, button:focus { outline: 2px solid #6c5ce7; outline-offset: 2px; }

/* Content warnings */
.content-warning { background: #fff3cd; border: 1px solid #ffeaa7; border-radius: 4px; padding: 1rem; margin: 1rem 0; }

.content-warning::before { content: "⚠️ Content Warning: "; font-weight: bold; }

/* Spoiler text */
.spoiler { background: #000; color: #000; cursor: pointer; user-select: none; }

.spoiler:hover, .spoiler.revealed { background: transparent; color: inherit; }

/* Community guidelines styling */
.guideline-section { border: 1px solid #e0e0e0; border-radius: 8px; padding: 1.5rem; margin: 1rem 0; }

.guideline-section.encourage { border-left: 4px solid #28a745; background: #f8fff9; }

.guideline-section.discourage { border-left: 4px solid #dc3545; background: #fff8f8; }

/* Resource cards */
.resource-card { background: white; border: 1px solid #e0e0e0; border-radius: 8px; padding: 1.5rem; margin: 1rem 0; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); transition: box-shadow 0.3s ease; }

.resource-card:hover { box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15); }

.resource-card h3 { color: #6c5ce7; margin-top: 0; }

/* FAQ styling */
.faq-item { border: 1px solid #e0e0e0; border-radius: 8px; margin: 1rem 0; overflow: hidden; }

.faq-question { background: #f8f9fa; padding: 1rem; cursor: pointer; user-select: none; font-weight: bold; }

.faq-question:hover { background: #e9ecef; }

.faq-answer { padding: 1rem; display: none; }

.faq-answer.open { display: block; }

/* Contact form styling */
.contact-method { background: white; border: 1px solid #e0e0e0; border-radius: 8px; padding: 1.5rem; margin: 1rem 0; text-align: center; }

.contact-method h3 { color: #6c5ce7; margin-top: 0; }

.contact-method .icon { font-size: 2rem; margin-bottom: 1rem; }

/* Navigation improvements */
.site-nav { background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px); }

/* Footer styling */
.site-footer { border-top: 4px solid; border-image: linear-gradient(90deg, #5bcefa, #f5a9b8, #ffffff, #f5a9b8, #5bcefa) 1; }

/* Print styles */
@media print { .hero-section, .site-header, .site-footer { display: none !important; }
  body { font-size: 12pt; line-height: 1.4; }
  a { text-decoration: underline; }
  a[href^="http"]:after { content: " (" attr(href) ")"; font-size: 0.8em; } }
/* Purple/Femme Theme */
:root { --primary-purple: #9b59b6; --light-purple: #c39bd3; --dark-purple: #6c3483; --lavender: #e8daef; --pink: #f5a9b8; --soft-pink: #fce4ec; }

body { color: #2c1a3d; background-color: white; }

a { color: var(--primary-purple); }

a:hover { color: var(--dark-purple); }

.site-header { background-color: white; border-bottom: 1px solid #e0e0e0; }

.site-title, .site-title:visited { color: var(--primary-purple) !important; }

.site-nav .page-link { color: var(--primary-purple); }

.site-nav .page-link:hover { color: var(--dark-purple); }

h1, h2, h3, h4, h5, h6 { color: var(--primary-purple); }

.page-heading { text-align: center; }

.home .page-heading { text-align: center; }

strong { color: var(--primary-purple); }

hr { border-color: var(--light-purple); }

a:focus, button:focus { outline: 2px solid var(--primary-purple); outline-offset: 2px; }

.site-footer { background-color: white; border-top: 1px solid #e0e0e0; color: var(--dark-purple); }

.site-footer a { color: var(--primary-purple); }

.site-footer a:hover { color: var(--dark-purple); }

/* Style for resource sections */
.resource-section { background: #f8f9fa; padding: 1.5rem; border-radius: 8px; margin: 1rem 0; border-left: 4px solid #6c5ce7; }

.resource-section h3 { color: #6c5ce7; margin-top: 0; }

/* Warning/alert boxes */
.alert-box { background: #fff3cd; border: 1px solid #ffeaa7; border-radius: 4px; padding: 1rem; margin: 1rem 0; }

.alert-box.danger { background: #f8d7da; border-color: #f5c6cb; color: #721c24; }

.alert-box.info { background: #d1ecf1; border-color: #bee5eb; color: #0c5460; }

.alert-box.success { background: #d4edda; border-color: #c3e6cb; color: #155724; }

/* Pride colors for accents */
.pride-accent { background: linear-gradient(90deg, #e40303, #ff8c00, #ffed00, #008018, #004cff, #732982); height: 4px; width: 100%; margin: 1rem 0; }

/* Trans flag accent */
.trans-accent { background: linear-gradient(90deg, #5bcefa, #f5a9b8, #ffffff, #f5a9b8, #5bcefa); height: 4px; width: 100%; margin: 1rem 0; }

/* Responsive design improvements */
@media screen and (max-width: 768px) { .hero-section h1 { font-size: 2rem !important; }
  .hero-section p { font-size: 1rem !important; }
  .hero-section a { padding: 0.75rem 1.5rem !important; font-size: 1rem !important; } }
/* Accessibility improvements */
.high-contrast { filter: contrast(150%); }

/* Focus indicators */
a:focus, button:focus { outline: 2px solid #6c5ce7; outline-offset: 2px; }

/* Content warnings */
.content-warning { background: #fff3cd; border: 1px solid #ffeaa7; border-radius: 4px; padding: 1rem; margin: 1rem 0; }

.content-warning::before { content: "⚠️ Content Warning: "; font-weight: bold; }

/* Spoiler text */
.spoiler { background: #000; color: #000; cursor: pointer; user-select: none; }

.spoiler:hover, .spoiler.revealed { background: transparent; color: inherit; }

/* Community guidelines styling */
.guideline-section { border: 1px solid #e0e0e0; border-radius: 8px; padding: 1.5rem; margin: 1rem 0; }

.guideline-section.encourage { border-left: 4px solid #28a745; background: #f8fff9; }

.guideline-section.discourage { border-left: 4px solid #dc3545; background: #fff8f8; }

/* Resource cards */
.resource-card { background: white; border: 1px solid #e0e0e0; border-radius: 8px; padding: 1.5rem; margin: 1rem 0; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); transition: box-shadow 0.3s ease; }

.resource-card:hover { box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15); }

.resource-card h3 { color: #6c5ce7; margin-top: 0; }

/* FAQ styling */
.faq-item { border: 1px solid #e0e0e0; border-radius: 8px; margin: 1rem 0; overflow: hidden; }

.faq-question { background: #f8f9fa; padding: 1rem; cursor: pointer; user-select: none; font-weight: bold; }

.faq-question:hover { background: #e9ecef; }

.faq-answer { padding: 1rem; display: none; }

.faq-answer.open { display: block; }

/* Contact form styling */
.contact-method { background: white; border: 1px solid #e0e0e0; border-radius: 8px; padding: 1.5rem; margin: 1rem 0; text-align: center; }

.contact-method h3 { color: #6c5ce7; margin-top: 0; }

.contact-method .icon { font-size: 2rem; margin-bottom: 1rem; }

/* Navigation improvements */
.site-nav { background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px); }

/* Footer styling */
.site-footer { border-top: 4px solid; border-image: linear-gradient(90deg, #5bcefa, #f5a9b8, #ffffff, #f5a9b8, #5bcefa) 1; }

/* Print styles */
@media print { .hero-section, .site-header, .site-footer { display: none !important; }
  body { font-size: 12pt; line-height: 1.4; }
  a { text-decoration: underline; }
  a[href^="http"]:after { content: " (" attr(href) ")"; font-size: 0.8em; } }
