Files
awesome-copilot/website/src/styles/starlight-overrides.css
JoeVenner 10e717202f feat(ui): comprehensive UI/UX improvements (#1069)
* feat(ui): replace emoji icons with SVG icon system

Replace all emoji icons with a consistent SVG icon system to improve:
- Visual consistency across platforms
- Design token control and theming
- Professional appearance

Changes:
- Add new Icon.astro component with 16 custom SVG icons
- Update index.astro to use SVG icons in resource cards
- Update index.ts to render SVG icons in search results
- Update utils.ts to return icon names instead of emojis
- Update global.css with proper SVG icon styling
- Remove emoji from Footer component

Icons added: robot, document, lightning, hook, workflow, plug, wrench, book,
plus action icons: close, copy, download, share, external, plus, search, chevron-down

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>

* feat(ui): enhance hero section, add animations and mobile responsiveness

Phase 2 & 3 UI/UX improvements:

Hero Section Enhancements:
- Add gradient text effect for title (purple to orange gradient)
- Add animated floating particles in hero background
- Increase hero padding for better visual impact

Card Category Colors:
- Add category-specific accent colors (AI, docs, power, automation, etc.)
- Each category has unique glow effect on hover
- Category colors: purple (AI), orange (docs), red (power), etc.

Entrance Animations:
- Add staggered fade-in animation for cards (50ms delay each)
- Cards animate in with translateY + opacity
- Add slide-down animation for search results

Mobile Responsiveness:
- Responsive grid: 4 cols → 2 cols → 1 col
- Adjust font sizes for mobile screens
- Add safe-area-inset support for notched devices
- Ensure touch targets ≥44px

Accessibility:
- Add prefers-reduced-motion support
- Disable animations for users who prefer reduced motion
- Smooth scroll with fallback

Additional Improvements:
- Add arrow indicator on card hover
- Add loading animation for count numbers
- Enhanced scrollbar styling
- Print styles for better printing

Co-Authored-By: Claude <noreply@anthropic.com>

* feat(ui): add theme toggle, enhanced search, and back to top button

Theme Toggle:
- Create ThemeToggle.astro component with sun/moon icons
- Add theme initialization in Head.astro to prevent flash
- Store theme preference in localStorage
- Keyboard shortcut: Cmd/Ctrl + Shift + L
- Smooth icon transition animation

Back to Top Button:
- Create BackToTop.astro component
- Appears after scrolling 400px
- Smooth scroll to top on click
- Fixed position bottom-right
- Respects reduced motion preference

Enhanced Search:
- Recent searches functionality with localStorage
- Show recent searches on focus when empty
- Remove individual items or clear all
- Enhanced empty state with icon and hint
- Cmd/Ctrl + K keyboard shortcut to focus search
- Add search to recent when getting results

CSS Enhancements:
- Theme toggle container styles
- Recent searches section styling
- Search empty state with icon
- Search loading spinner
- Keyboard shortcut hint styles
- Print styles for new components

Co-Authored-By: Claude <noreply@anthropic.com>

* fix(ui): resolve header and theme toggle issues

- Add Copilot logo to header via Starlight config with automatic theme switching
- Fix theme toggle slider direction (was reversed)
- Fix theme toggle active icon highlighting (was backwards)
- Change theme toggle from purple circle slider to bold text indicator
- Fix theme toggle slider overflow by adding overflow: hidden
- Remove duplicate banner image from home page
- Clean up conflicting logo CSS rules to prevent duplication

The header now displays: [ Copilot Icon ] Awesome GitHub Copilot [ Search ]
Theme toggle indicators are now visually clear with bold text for selected theme.

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>

* fix(ui): address feedback on UI/UX improvements

- Remove logo from header per brand guidance (logo config and CSS)
- Fix back-to-top button visibility by moving to body level and using global styles
- Fix modal visibility by adding 'visible' class for CSS animations
- Fix theme toggle applying site-wide by using global styles and proper theme initialization
- Update icons to use GitHub Primer SVG icons with proper fill-based styling
- Fix plugin modal to render SVG icons instead of icon names
- Add theme initialization script to prevent flash of unstyled content

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>

* fix: move modal to body level to fix z-index stacking context issue

The modal was nested inside .main-pane which has isolation: isolate,
creating a new stacking context. This caused the modal's z-index
to be evaluated within that context, unable to stack above the header.

This fix moves the modal to be a direct child of body on page load,
allowing it to properly cover the entire viewport including navbar.

---------

Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-23 10:13:29 +11:00

240 lines
6.9 KiB
CSS

/* Brand color overrides for Starlight */
/* Purple (#8534F3) and Orange (#FE4C25) theme */
/* ── Dark theme (default) ─────────────────────────────────── */
:root {
--sl-color-accent-low: #1a0d33;
--sl-color-accent: #8534f3;
--sl-color-accent-high: #c9a5fa;
--sl-color-text-accent: #c9a5fa;
--sl-color-white: #f0f0f5;
--sl-color-gray-1: #d0d0da;
--sl-color-gray-2: #9898a6;
--sl-color-gray-3: #60607a;
--sl-color-gray-4: #30304a;
--sl-color-gray-5: #1a1a2e;
--sl-color-gray-6: #0d0d12;
--sl-color-black: #0d0d12;
--sl-font-system: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica,
Arial, sans-serif;
}
/* ── Light theme ───────────────────────────────────────────── */
/* Starlight inverts the gray scale for light mode.
Because our customCss is unlayered it overrides Starlight's layered
theme swap, so we must provide the inverted palette ourselves. */
:root[data-theme="light"] {
--sl-color-accent-low: #f0e6ff;
--sl-color-accent: #6b21c8;
--sl-color-accent-high: #3b0d7a;
--sl-color-text-accent: #6b21c8;
--sl-color-white: #0a0a0f;
--sl-color-gray-1: #111120;
--sl-color-gray-2: #1a1a2e;
--sl-color-gray-3: #30304a;
--sl-color-gray-4: #60607a;
--sl-color-gray-5: #9898a6;
--sl-color-gray-6: #f5f5f7;
--sl-color-black: #fafafa;
}
:root[data-theme="light"] header.header {
background: rgba(250, 250, 250, 0.6) !important;
border-bottom: 1px solid rgba(0, 0, 0, 0.08) !important;
}
/* ── Sidebar readability ───────────────────────────────────── */
nav[aria-label="Main"] a {
font-weight: 500 !important;
}
nav[aria-label="Main"] a[aria-current="page"] {
color: var(--sl-color-text-invert) !important;
font-weight: 600 !important;
border-inline-start-color: var(--sl-color-accent) !important;
}
/* ── Header brand styling ──────────────────────────────────── */
.site-title {
font-weight: 700 !important;
}
header .site-title:hover {
color: var(--sl-color-accent-high) !important;
}
/* ── Unified background ─────────────────────────────────────── */
/* Clean header - solid background */
header.header {
background: var(--sl-color-gray-6) !important;
border-bottom: 1px solid var(--sl-color-gray-5) !important;
z-index: 1000;
position: relative;
}
/* Header inner content for alignment */
header.header .header-inner {
display: flex;
align-items: center;
justify-content: space-between;
max-width: 100%;
}
header.header .header-actions {
display: flex;
align-items: center;
gap: 12px;
}
/* Hide social icons in header - GitHub link moved to hero */
header .social-icons {
display: none !important;
}
/* Move theme toggle inside header - align with header elements */
.theme-toggle-container {
position: fixed !important;
top: 12px !important;
right: 80px !important;
z-index: 1001;
}
/* On custom splash pages, body already has the gradient bg.
Make Starlight's wrapper layers transparent so it shows through. */
body:has(#main-content) {
--sl-color-bg: transparent;
--sl-color-bg-nav: transparent;
}
/* ── Hide Starlight's built-in theme selector (dropdown) ─── */
/* We use our own custom ThemeToggle component instead */
starlight-theme-select {
display: none !important;
}
/* ── Browse Resources sidebar group ────────────────────────── */
nav[aria-label="Main"] > ul > li:first-child details summary,
nav[aria-label="Main"] > ul > li:first-child > a {
font-weight: 600;
}
/* ── Hide Starlight's auto-generated page title on custom splash pages ── */
/* Only affects pages that have their own #main-content (custom pages) */
/* Starlight generates a title h1; custom pages render their own h1 */
main:has(#main-content) > .content-panel:has(h1#_top) {
display: none !important;
}
/* ── Pagefind search filter pills ──────────────────────────── */
/* Restyle the default checkbox filters as horizontal pill toggles above results */
/* Stack filters above results instead of side-by-side */
#starlight__search .pagefind-ui__drawer {
flex-direction: column !important;
}
#starlight__search .pagefind-ui__filter-panel {
border: none;
padding: 0;
margin: 0;
width: 100% !important;
min-width: 0 !important;
flex: none !important;
}
#starlight__search .pagefind-ui__filter-panel-label {
display: none;
}
/* Remove the collapsible <details> wrapper — always show filters */
#starlight__search .pagefind-ui__filter-block {
border: none;
margin: 0;
padding: 0;
}
#starlight__search .pagefind-ui__filter-block > summary {
display: none;
}
/* Hide the "type" group legend */
#starlight__search .pagefind-ui__filter-group-label {
display: none;
}
/* Lay out filter values as a horizontal pill row */
#starlight__search .pagefind-ui__filter-group {
display: flex !important;
flex-direction: row !important;
flex-wrap: wrap !important;
align-items: center !important;
gap: 0.375rem;
padding: 0.375rem 0 0.625rem;
border: none;
margin: 0;
}
/* Each pill: hide the checkbox, style the label as a pill */
#starlight__search .pagefind-ui__filter-value {
display: contents;
}
/* Visually hidden but still focusable for keyboard a11y */
#starlight__search .pagefind-ui__filter-checkbox {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}
#starlight__search .pagefind-ui__filter-value::before {
display: none !important;
}
#starlight__search .pagefind-ui__filter-label {
display: inline-flex !important;
width: auto !important;
align-items: center;
padding: 0.2rem 0.625rem;
border-radius: 9999px;
font-size: 0.75rem;
font-weight: 500;
line-height: 1.4;
cursor: pointer;
user-select: none;
transition: all 0.15s ease;
border: 1px solid var(--sl-color-gray-5);
color: var(--sl-color-gray-2);
background: transparent;
text-transform: capitalize;
}
#starlight__search .pagefind-ui__filter-label:hover {
border-color: var(--sl-color-accent);
color: var(--sl-color-accent-high);
}
/* Keyboard focus ring for pill filters */
#starlight__search .pagefind-ui__filter-checkbox:focus-visible + .pagefind-ui__filter-label {
outline: 2px solid var(--sl-color-accent);
outline-offset: 2px;
}
/* Active/checked pill state */
#starlight__search .pagefind-ui__filter-checkbox:checked + .pagefind-ui__filter-label {
background: var(--sl-color-accent);
border-color: var(--sl-color-accent);
color: white;
}
#starlight__search .pagefind-ui__filter-checkbox:checked + .pagefind-ui__filter-label:hover {
opacity: 0.9;
}