/* ========================= CSS Variables & Theming ========================= */ :root { /* Color Palette */ --color-primary: #008AFF; --color-secondary: #404040; --color-accent: #F5F5F5; --color-bg: #FFF; --color-surface: #EEE; --color-navbar-bg: #EEE; --color-navbar-border: #CCC; --color-text: #404040; --color-success: #4caf50; --color-warning: #ff9800; --color-danger: #e53935; --color-info: #50afff; --color-code-bg: #f5f5f5; --color-code-text: #222; --color-share-bg: #b5c6ce; --color-btn-bg: #0085a1; --color-btn-text: #fff; --color-btn-border: #0085a1; --color-btn-shadow: 1px 1px 2px #aaa; /* Typography */ --font-primary: Verdana, Tahoma, 'Trebuchet MS', Arial, sans-serif; --font-mono: 'Courier New', Courier, monospace; --font-size-base: 18px; --font-size-sm: 14px; --font-size-lg: 30px; --font-size-xl: 50px; /* Borders */ --border-color: var(--color-surface); --border-contrast: #222; /* High-contrast border for light mode */ --border-width: 1px; --border-radius: 4px; --border-radius-round: 50%; --border-style: solid; /* Spacing */ --space-xs: 5px; --space-sm: 10px; --space-md: 15px; --space-lg: 30px; --space-xl: 50px; /* Shadows */ --shadow-sm: 1px 1px 3px rgba(0,0,0,0.15); --shadow-md: 0 0 8px rgba(0,0,0,0.15); --shadow-btn: 1px 1px 2px #aaa; } @media (prefers-color-scheme: dark) { :root { /* Color Palette */ --color-primary: #50afff; --color-secondary: #b0b0b0; --color-accent: #505050; --color-bg: #181818; --color-surface: var(--color-bg); --color-navbar-bg: #181e24; --color-navbar-border: #444; --color-text: #EEE; --color-success: #6fdc8c; --color-warning: #ffb74d; --color-danger: #ff6565; --color-info: #50afff; --color-code-bg: #333; --color-code-text: #ccc; --color-share-bg: #3b4d56; --color-btn-bg: #222a3a; --color-btn-text: #fff; --color-btn-border: #50afff; --color-btn-shadow: 1px 1px 2px #333; /* Typography */ --font-primary: Verdana, Tahoma, 'Trebuchet MS', Arial, sans-serif; --font-mono: 'Courier New', Courier, monospace; --font-size-base: 18px; --font-size-sm: 14px; --font-size-lg: 30px; --font-size-xl: 50px; /* Borders */ --border-color: var(--color-secondary); --border-contrast: #fff; /* High-contrast border for dark mode */ --border-width: 1px; --border-radius: 4px; --border-radius-round: 50%; --border-style: solid; /* Spacing */ --space-xs: 5px; --space-sm: 10px; --space-md: 15px; --space-lg: 30px; --space-xl: 50px; /* Shadows */ --shadow-sm: 1px 1px 3px rgba(0,0,0,0.5); --shadow-md: 0 0 8px rgba(0,0,0,0.5); --shadow-btn: 1px 1px 2px #111; } } /* Section: Horizontal Rule */ hr { border: none; border-top: 2px solid var(--color-secondary); margin: var(--space-lg) 0; } /* Section: Navbar */ .navbar, .navbar-custom { background: var(--color-navbar-bg); border-bottom: var(--border-width) solid var(--color-navbar-border); font-weight: 800; font-family: var(--font-primary); } .navbar a:hover, .navbar-custom a:hover { color: var(--color-primary) !important; text-decoration: underline !important; } /* Section: Headings */ h1, h2, h3, h4, h5, h6 { font-family: var(--font-primary); font-weight: 800; margin-top: var(--space-lg); margin-bottom: var(--space-md); color: var(--color-secondary); } h1 { font-size: var(--font-size-xl); padding-top: var(--space-xl); } h2 { font-size: calc(var(--font-size-lg) + 8px); } h3 { font-size: var(--font-size-lg); } h4 { font-size: calc(var(--font-size-base) + 6px); } h5 { font-size: var(--font-size-base); } h6 { font-size: var(--font-size-sm); } /* Section: Responsive Images */ img { max-width: 100%; height: auto; display: block; background: var(--color-bg); color: var(--color-text); border-color: var(--border-contrast); border: calc(2 * var(--border-width)) dashed var(--border-contrast) !important; border-radius: var(--border-radius); } img::selection, img::-moz-selection { color: white; } /* Section: Classic Dashed Borders */ .well, .blog-post, .post-preview, .panel, .list-group-item, .error-text, .highlight { background: var(--color-bg); color: var(--color-text); } .well, .blog-post, .post-preview, .panel, .highlight { border-color: var(--border-contrast); border: calc(2 * var(--border-width)) dashed var(--border-contrast) !important; border-radius: var(--border-radius); box-sizing: border-box; margin: var(--space-md) auto; padding: var(--space-md); } /* Utility: Hide Element */ .hideme { display: none !important; } /* Utility: Code/Panel Border Radius */ pre, code, .panel, .highlight { padding: 0; margin: 0; border-radius: var(--border-radius); } .btn { background-color: var(--color-btn-bg); color: var(--color-btn-text); border: var(--border-width) solid var(--color-btn-border); border-radius: var(--border-radius); box-shadow: var(--shadow-btn); padding: var(--space-sm) var(--space-md); font-size: var(--font-size-base); font-family: var(--font-primary); text-transform: uppercase; font-weight: 800; letter-spacing: 1px; cursor: pointer; } .btn:hover, .btn:focus { background-color: var(--color-btn-bg); color: var(--color-btn-text); border: var(--border-width) solid var(--color-btn-border); box-shadow: var(--shadow-btn); } /* Section: Body and layout */ body { font-family: var(--font-primary); font-size: var(--font-size-base); color: var(--color-text); position: relative; background: var(--color-bg); min-height: 100vh; } *, *::before, *::after { box-sizing: border-box; } /* Section: Color Accent for Links */ ::-moz-selection, ::selection { color: white; text-shadow: none; background: var(--color-accent); } /* Section: Disqus Comments */ .disqus-comments button { @extend .btn; } .disqus-comments button:hover, .disqus-comments button:focus { color: var(--color-bg); background: var(--color-accent); border: var(--border-width) solid var(--color-primary); } /* Section: Copy Code Button */ .copyCodeButton { background-color: var(--color-code-bg); border: var(--border-width) solid var(--border-color); color: black; cursor: pointer; display: none; font-size: var(--font-size-sm); padding: var(--space-xs) var(--space-sm); position: absolute; right: 10px; top: 10px; transition: background-color 0.3s ease; z-index: 10; } .copyCodeButton:hover { background-color: var(--color-secondary); } /* Section: Google Translate Customization */ .googleTranslate { font-family: var(--font-primary); font-size: var(--font-size-base); color: var(--color-text); background: var(--color-bg); border-radius: var(--border-radius); border: calc(2 * var(--border-width)) dashed var(--border-contrast) !important; padding: var(--space-sm); box-shadow: var(--shadow-sm); display: block; max-width: 100%; width: 100%; box-sizing: border-box; overflow-x: auto; } .googleTranslate .goog-te-gadget img { filter: grayscale(100%); } .googleTranslate .goog-te-combo { background: var(--color-bg); color: var(--color-text); border: var(--border-width) solid var(--border-contrast); border-radius: var(--border-radius); font-family: var(--font-primary); font-size: 125%; padding: var(--space-xs) var(--space-sm); margin: 0 5px; box-shadow: var(--shadow-sm); transition: border-color 0.2s, box-shadow 0.2s; width: 100%; min-width: 120px; max-width: 100%; box-sizing: border-box; white-space: normal; overflow-x: auto; } .googleTranslate .goog-te-combo:focus, .googleTranslate .goog-te-combo:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); outline: none; } /* Section: Share Buttons */ ul.share li a { background-color: var(--color-share-bg); display: block; border-radius: var(--border-radius-round); text-decoration: none !important; margin: 0; } ul.share li .fab { display: block; width: 30px; height: 30px; line-height: 30px; font-size: 16px; text-align: center; transition: all 150ms ease-in-out; color: var(--color-bg); } ul.share li:hover .fab { transform: scale(1.4) } /* Responsive tweaks for Google Translate on mobile */ @media (max-width: 600px) { .googleTranslate { font-size: 16px; padding: var(--space-xs); } .googleTranslate .goog-te-combo { font-size: 100%; } }