/* Search - Privacy-Respecting Metasearch Engine
 * Main stylesheet with Dracula theme (dark) and light theme
 * Mobile-first responsive design
 */

/* CSS Variables - Dracula Theme (Dark) - Default */
/* Per AI.md PART 16: Apply theme class to <html> element: theme-light, theme-dark */
:root,
html.theme-dark {
    --bg-primary: #282a36;
    --bg-secondary: #44475a;
    --bg-tertiary: #1e1f29;
    --text-primary: #f8f8f2;
    --text-secondary: #6272a4;
    --text-muted: #6272a4;
    --accent-primary: #bd93f9;
    --accent-secondary: #ff79c6;
    --accent-success: #50fa7b;
    --accent-warning: #ffb86c;
    --accent-error: #ff5555;
    --accent-info: #8be9fd;
    --border-color: #44475a;
    --shadow-color: rgba(0, 0, 0, 0.3);
    --input-bg: #44475a;
    --input-border: #6272a4;
    --input-focus: #bd93f9;
    --link-color: #8be9fd;
    --link-hover: #bd93f9;
}

/* Light Theme */
/* Per AI.md PART 16: Apply theme class to <html> element */
html.theme-light {
    --bg-primary: #f8f8f2;
    --bg-secondary: #ffffff;
    --bg-tertiary: #e8e8e8;
    --text-primary: #282a36;
    --text-secondary: #44475a;
    --text-muted: #6272a4;
    --accent-primary: #7c3aed;
    --accent-secondary: #db2777;
    --accent-success: #059669;
    --accent-warning: #d97706;
    --accent-error: #dc2626;
    --accent-info: #0284c7;
    --border-color: #e5e7eb;
    --shadow-color: rgba(0, 0, 0, 0.1);
    --input-bg: #ffffff;
    --input-border: #d1d5db;
    --input-focus: #7c3aed;
    --link-color: #0284c7;
    --link-hover: #7c3aed;
}

/* Reset */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* Responsive Container (per AI.md PART 17)
 * >=720px: 90% width with 5% margins
 * <720px: 98% width with 1% margins
 */
.container {
    width: 98%;
    margin: 0 auto;
    max-width: 1400px;
}

@media (min-width: 720px) {
    .container {
        width: 90%;
    }
}

/* Base */
html {
    font-size: 16px;
    scroll-behavior: smooth;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    background-color: var(--bg-primary);
    color: var(--text-primary);
    line-height: 1.6;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

a {
    color: var(--link-color);
    text-decoration: none;
    transition: color 0.2s ease;
}

a:hover {
    color: var(--link-hover);
    text-decoration: underline;
}

/* Header */
.site-header {
    background-color: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
    position: sticky;
    top: 0;
    z-index: 100;
}

.nav-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0.75rem 1rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}

.logo {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--accent-primary);
    font-weight: 700;
    font-size: 1.25rem;
    text-decoration: none;
}

.logo:hover {
    color: var(--accent-primary);
    text-decoration: none;
}

.logo-icon {
    font-size: 1.5rem;
}

.logo-img {
    height: 32px;
    width: auto;
}

.header-search {
    flex: 1;
    max-width: 500px;
    display: flex;
}

.header-search-input {
    flex: 1;
    padding: 0.5rem 1rem;
    background-color: var(--input-bg);
    border: 1px solid var(--input-border);
    border-right: none;
    border-radius: 20px 0 0 20px;
    color: var(--text-primary);
    font-size: 0.9rem;
}

.header-search-input:focus {
    outline: none;
    border-color: var(--input-focus);
}

.header-search-btn {
    padding: 0.5rem 1rem;
    background-color: var(--accent-primary);
    border: 1px solid var(--accent-primary);
    border-radius: 0 20px 20px 0;
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    transition: background-color 0.2s ease;
}

.header-search-btn:hover {
    background-color: var(--accent-secondary);
    border-color: var(--accent-secondary);
}

.nav-links {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.nav-link {
    color: var(--text-secondary);
    font-size: 0.9rem;
    padding: 0.5rem;
}

.nav-link:hover,
.nav-link.active {
    color: var(--accent-primary);
}

.theme-toggle {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0.5rem;
    display: flex;
    align-items: center;
}

.theme-toggle:hover {
    color: var(--accent-primary);
}

/* Per AI.md PART 16: Use CSS classes on <html> element */
html.theme-dark .theme-icon-light,
html.theme-light .theme-icon-dark {
    display: none;
}

/* Navigation bar - separate row below header per AI.md PART 16 */
.nav {
    background-color: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
    padding: 0.5rem 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1200px;
    margin: 0 auto;
}

/* Hidden checkbox controls menu state - NO JavaScript per AI.md PART 16 */
.nav-checkbox {
    display: none;
}

/* Hamburger toggle (label) - hidden on desktop per AI.md PART 16 */
.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 4px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
}

.nav-toggle span {
    display: block;
    width: 24px;
    height: 2px;
    background-color: var(--text-primary);
    transition: transform 0.2s ease;
}

/* Mobile nav panel (slide-in menu) - hidden off-screen by default */
.nav-panel {
    position: fixed;
    top: 0;
    right: -280px;
    width: 280px;
    height: 100vh;
    background-color: var(--bg-secondary);
    border-left: 1px solid var(--border-color);
    z-index: 1001;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    transition: right 0.3s ease;
}

/* Close button in nav panel */
.nav-close {
    align-self: flex-end;
    font-size: 1.5rem;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0.5rem;
    line-height: 1;
}

.nav-close:hover {
    color: var(--text-primary);
}

.nav-panel-link {
    display: block;
    padding: 0.75rem 1rem;
    color: var(--text-primary);
    border-radius: 6px;
}

.nav-panel-link:hover,
.nav-panel-link.active {
    background-color: var(--bg-tertiary);
    color: var(--accent-primary);
}

.nav-panel-theme {
    margin-top: 1rem;
    padding: 0.75rem 1rem;
    text-align: left;
}

/* Nav overlay (label) - hidden by default */
.nav-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1000;
    cursor: pointer;
}

/* CSS-only mobile menu: checkbox :checked triggers panel and overlay */
.nav-checkbox:checked ~ .nav-panel {
    right: 0;
}

.nav-checkbox:checked ~ .nav-overlay {
    display: block;
}

/* Desktop: show inline links, hide hamburger per AI.md PART 16 */
@media (min-width: 769px) {
    .nav-toggle,
    .nav-panel,
    .nav-overlay,
    .nav-close {
        display: none !important;
    }

    .nav-links {
        display: flex;
    }
}

/* Backward compat - remove old overlay styles */
.nav-overlay-old {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 999;
}

.nav-overlay.active {
    display: block;
}

/* Main Content */
.main-content {
    flex: 1;
    width: 100%;
}

/* Flash Messages */
.flash {
    max-width: 1200px;
    margin: 1rem auto;
    padding: 1rem;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.flash-success {
    background-color: rgba(80, 250, 123, 0.2);
    border: 1px solid var(--accent-success);
    color: var(--accent-success);
}

.flash-error {
    background-color: rgba(255, 85, 85, 0.2);
    border: 1px solid var(--accent-error);
    color: var(--accent-error);
}

.flash-warning {
    background-color: rgba(255, 184, 108, 0.2);
    border: 1px solid var(--accent-warning);
    color: var(--accent-warning);
}

.flash-info {
    background-color: rgba(139, 233, 253, 0.2);
    border: 1px solid var(--accent-info);
    color: var(--accent-info);
}

.flash-close {
    background: none;
    border: none;
    color: inherit;
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0;
    line-height: 1;
}

/* Home Page */
.home-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - 200px);
    padding: 2rem 1rem;
    text-align: center;
}

.logo-section {
    margin-bottom: 2rem;
}

.home-logo {
    font-size: clamp(2rem, 8vw, 3.5rem);
    color: var(--accent-primary);
    margin-bottom: 0.5rem;
}

.home-logo-img {
    max-width: 200px;
    height: auto;
    margin-bottom: 1rem;
}

.home-tagline {
    color: var(--text-secondary);
    font-size: clamp(1rem, 3vw, 1.25rem);
}

/* Search Form */
.search-form {
    width: 100%;
    max-width: 650px;
}

.search-box {
    display: flex;
    margin-bottom: 1.5rem;
    box-shadow: 0 4px 16px var(--shadow-color);
    border-radius: 28px;
    overflow: hidden;
}

.search-input {
    flex: 1;
    padding: 1rem 1.5rem;
    font-size: 1rem;
    background-color: var(--input-bg);
    border: 2px solid var(--border-color);
    border-right: none;
    color: var(--text-primary);
    outline: none;
}

.search-input:focus {
    border-color: var(--accent-primary);
}

.search-input::placeholder {
    color: var(--text-muted);
}

.search-btn {
    padding: 1rem 1.5rem;
    background-color: var(--accent-primary);
    border: 2px solid var(--accent-primary);
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease;
}

.search-btn:hover {
    background-color: var(--accent-secondary);
    border-color: var(--accent-secondary);
}

.search-btn:disabled,
.search-btn.submitting {
    opacity: 0.7;
    cursor: not-allowed;
}

.btn:disabled,
.btn.submitting {
    opacity: 0.7;
    cursor: not-allowed;
}

/* Category Tabs */
.category-tabs {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 2rem;
}

.category-tab {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
    padding: 0.75rem 1rem;
    background-color: var(--bg-secondary);
    border: 2px solid var(--border-color);
    border-radius: 12px;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 70px;
}

.category-tab:hover {
    border-color: var(--accent-primary);
    color: var(--accent-primary);
}

.category-tab.active {
    background-color: rgba(189, 147, 249, 0.15);
    border-color: var(--accent-primary);
    color: var(--accent-primary);
}

.tab-icon {
    font-size: 1.25rem;
}

.tab-text {
    font-size: 0.75rem;
    font-weight: 500;
}

/* Home Features */
.home-features {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
    justify-content: center;
}

.feature {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.feature-icon {
    font-size: 1.25rem;
}

/* Announcements */
.announcements-container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto 1rem auto;
    padding: 0 1rem;
}

.announcement {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    margin-bottom: 0.5rem;
    animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.announcement-warning {
    background-color: rgba(255, 184, 108, 0.15);
    border: 1px solid var(--accent-warning);
    color: var(--accent-warning);
}

.announcement-info {
    background-color: rgba(139, 233, 253, 0.15);
    border: 1px solid var(--accent-info);
    color: var(--accent-info);
}

.announcement-error {
    background-color: rgba(255, 85, 85, 0.15);
    border: 1px solid var(--accent-error);
    color: var(--accent-error);
}

.announcement-success {
    background-color: rgba(80, 250, 123, 0.15);
    border: 1px solid var(--accent-success);
    color: var(--accent-success);
}

.announcement-content {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.announcement-title {
    font-weight: 600;
}

.announcement-message {
    color: var(--text-primary);
}

.announcement-dismiss {
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0 0.5rem;
    line-height: 1;
    opacity: 0.7;
    transition: opacity 0.2s;
    color: inherit;
}

.announcement-dismiss:hover {
    opacity: 1;
}

/* Cookie Consent */
.cookie-consent {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
    padding: 1rem;
    z-index: 1000;
    box-shadow: 0 -2px 10px var(--shadow-color);
}

.cookie-consent-content {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.cookie-consent-text {
    flex: 1;
    min-width: 200px;
}

.cookie-consent-text a {
    color: var(--link-color);
}

.cookie-consent-buttons {
    display: flex;
    gap: 0.5rem;
}

.cookie-accept,
.cookie-decline {
    padding: 0.5rem 1rem;
    border-radius: 0.375rem;
    cursor: pointer;
    font-size: 0.875rem;
}

.cookie-accept {
    background-color: var(--accent-primary);
    color: var(--bg-primary);
    border: none;
}

.cookie-decline {
    background-color: transparent;
    color: var(--text-secondary);
    border: 1px solid var(--border-color);
}

/* Footer - per AI.md PART 17 */
.footer,
.site-footer {
    background-color: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
    padding: 1.5rem 1rem;
    margin-top: auto;
    text-align: center;
}

.footer p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.footer p a {
    color: var(--text-secondary);
}

.footer p a:hover {
    color: var(--accent-primary);
}

.footer p span {
    color: var(--text-muted);
    margin: 0 0.25rem;
}

.footer br {
    display: block;
    margin: 0.5rem 0;
    content: "";
}

.footer a {
    color: var(--text-muted);
    font-size: 0.85rem;
}

.footer-container {
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
}

.footer-links {
    display: flex;
    gap: 1.5rem;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.footer-links a {
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.footer-links a:hover {
    color: var(--accent-primary);
}

.footer-info {
    color: var(--text-muted);
    font-size: 0.85rem;
}

.footer-version {
    margin-top: 0.5rem;
    font-size: 0.75rem;
}

/* Tor hidden service address in footer - per AI.md PART 32 */
.tor-address {
    margin-bottom: 0.75rem;
    padding: 0.5rem 1rem;
    background-color: var(--bg-tertiary);
    border-radius: var(--radius-md, 0.5rem);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    max-width: 100%;
    overflow: hidden;
}

.tor-icon {
    font-size: 1.1rem;
    flex-shrink: 0;
}

.onion-link {
    font-family: var(--font-mono, monospace);
    font-size: 0.85rem;
    color: var(--accent-primary);
    word-break: break-all;
    overflow-wrap: anywhere;
    min-width: 0;
}

.onion-link:hover {
    color: var(--accent-secondary);
    text-decoration: underline;
}

/* Mobile: stack tor address vertically and truncate with ellipsis */
@media (max-width: 480px) {
    .tor-address {
        flex-direction: column;
        padding: 0.5rem 0.75rem;
        text-align: center;
    }

    .onion-link {
        font-size: 0.7rem;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
}

/* Search Results Page */
.search-results-page {
    max-width: 800px;
    margin: 0 auto;
    padding: 1.5rem 1rem;
}

.search-categories {
    display: flex;
    gap: 0.5rem;
    padding: 0.75rem 0;
    margin-bottom: 1rem;
    border-bottom: 1px solid var(--border-color);
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.search-categories::-webkit-scrollbar {
    display: none;
}

.category-link {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 1rem;
    border-radius: 20px;
    color: var(--text-secondary);
    font-size: 0.9rem;
    white-space: nowrap;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}

.category-link:hover {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    text-decoration: none;
}

.category-link.active {
    background-color: var(--accent-primary);
    color: var(--bg-primary);
    font-weight: 500;
}

.category-link .cat-icon {
    font-size: 1rem;
}

.search-info {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-muted);
    font-size: 0.85rem;
    margin-bottom: 1.5rem;
    padding-left: 0.25rem;
}

.search-error {
    background-color: rgba(255, 85, 85, 0.1);
    border: 1px solid var(--accent-error);
    border-radius: 12px;
    padding: 1.5rem;
    text-align: center;
    color: var(--accent-error);
}

/* Instant Answer Box */
.instant-answer-box {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
    border: 1px solid var(--accent-primary);
    border-radius: 12px;
    padding: 1.25rem;
    margin-bottom: 1.5rem;
    box-shadow: 0 4px 15px var(--shadow-color);
}

.instant-answer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--border-color);
}

.instant-answer-title {
    font-weight: 600;
    color: var(--accent-primary);
    font-size: 0.9rem;
}

.instant-answer-source {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-decoration: none;
}

.instant-answer-source:hover {
    color: var(--link-hover);
}

.instant-answer-content {
    color: var(--text-primary);
    font-size: 1rem;
    line-height: 1.6;
}

.instant-answer-content strong {
    color: var(--accent-info);
}

.instant-answer-content em {
    color: var(--text-secondary);
    font-style: italic;
}

/* Instant Answer Type-Specific Styles */
.instant-answer-box[data-type="math"] .instant-answer-content,
.instant-answer-box[data-type="convert"] .instant-answer-content {
    font-family: 'SF Mono', Consolas, 'Liberation Mono', monospace;
    font-size: 1.1rem;
}

.instant-answer-box[data-type="definition"] .instant-answer-content {
    font-size: 0.95rem;
}

.instant-answer-content .math-result,
.instant-answer-content .conversion-result {
    font-size: 1.5rem;
    padding: 0.5rem 0;
}

.instant-answer-content .math-result .result,
.instant-answer-content .conversion-result strong {
    color: var(--accent-success);
    font-weight: 700;
}

.instant-answer-content .expression {
    color: var(--text-secondary);
}

.instant-answer-content .phonetic {
    color: var(--text-muted);
    font-style: italic;
}

.instant-answer-content .example {
    color: var(--text-muted);
    font-style: italic;
    font-size: 0.9rem;
}

/* Hash result formatting */
.instant-answer-content .hash-result {
    word-break: break-all;
    font-family: 'SF Mono', Consolas, monospace;
    background: var(--bg-tertiary);
    padding: 0.75rem;
    border-radius: 6px;
    font-size: 0.85rem;
}

/* Color preview */
.instant-answer-content .color-preview {
    display: inline-block;
    width: 24px;
    height: 24px;
    border-radius: 4px;
    margin-right: 0.5rem;
    vertical-align: middle;
    border: 1px solid var(--border-color);
}

/* Time display */
.instant-answer-content .time-result {
    font-size: 2rem;
    font-weight: 600;
    color: var(--accent-info);
}

.instant-answer-content .date-result {
    font-size: 1.1rem;
    color: var(--text-secondary);
}

.no-results {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text-secondary);
}

.no-results p {
    margin-bottom: 0.5rem;
}

.no-results-hint {
    font-size: 0.9rem;
    color: var(--text-muted);
}

/* Result Cards */
.results-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.result-item {
    background-color: var(--bg-secondary);
    border-radius: 12px;
    padding: 1.25rem;
    border: 1px solid var(--border-color);
    transition: all 0.2s ease;
    display: flex;
    gap: 1rem;
}

.result-item:hover {
    border-color: var(--accent-primary);
    box-shadow: 0 4px 20px var(--shadow-color);
    transform: translateY(-2px);
}

.result-favicon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background-color: var(--bg-tertiary);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.result-favicon img {
    width: 20px;
    height: 20px;
    object-fit: contain;
}

.result-favicon .favicon-placeholder {
    width: 20px;
    height: 20px;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 700;
    color: white;
    text-transform: uppercase;
}

.result-body {
    flex: 1;
    min-width: 0;
}

.result-title {
    margin: 0 0 0.4rem 0;
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.3;
}

.result-title a {
    color: var(--accent-primary);
    text-decoration: none;
    transition: color 0.2s;
}

.result-title a:hover {
    color: var(--accent-secondary);
    text-decoration: underline;
}

.result-url {
    color: var(--accent-success);
    font-size: 0.8rem;
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.result-url-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.result-description {
    color: var(--text-secondary);
    font-size: 0.9rem;
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.result-meta {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: 0.75rem;
    font-size: 0.75rem;
    color: var(--text-muted);
}

.result-engine {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.2rem 0.6rem;
    background-color: var(--bg-tertiary);
    border-radius: 12px;
    font-weight: 500;
    text-transform: capitalize;
}

.result-date {
    color: var(--text-muted);
}

/* Pagination */
.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 2rem 0;
    margin-top: 1rem;
}

.page-link {
    padding: 0.75rem 1.25rem;
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    font-weight: 500;
    transition: all 0.2s ease;
}

.page-link:hover {
    background-color: var(--accent-primary);
    border-color: var(--accent-primary);
    color: var(--bg-primary);
    text-decoration: none;
}

.page-info {
    color: var(--text-muted);
    font-size: 0.9rem;
}

/* Infinite Scroll */
.infinite-scroll-trigger {
    height: 1px;
    margin-top: 2rem;
}

.loading-more {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 2rem;
    color: var(--text-muted);
}

.loading-spinner {
    width: 24px;
    height: 24px;
    border: 3px solid var(--border-color);
    border-top-color: var(--accent-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

.end-of-results {
    text-align: center;
    padding: 2rem;
    color: var(--text-muted);
    font-size: 0.9rem;
}

/* Image Results */
.image-results {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
}

.image-result {
    background-color: var(--bg-secondary);
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border-color);
    transition: all 0.2s ease;
}

.image-result:hover {
    border-color: var(--accent-primary);
    box-shadow: 0 4px 20px var(--shadow-color);
    transform: translateY(-2px);
}

.image-result a {
    display: block;
}

.image-result img {
    width: 100%;
    height: 160px;
    object-fit: cover;
    background-color: var(--bg-tertiary);
}

.image-placeholder {
    width: 100%;
    height: 160px;
    background-color: var(--bg-tertiary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    color: var(--text-muted);
}

.image-result-info {
    padding: 0.75rem;
}

.image-title {
    color: var(--text-primary);
    font-size: 0.85rem;
    font-weight: 500;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-decoration: none;
}

.image-title:hover {
    color: var(--accent-primary);
}

.image-source {
    color: var(--text-muted);
    font-size: 0.75rem;
    margin-top: 0.35rem;
    text-transform: capitalize;
}

/* Video Results */
.video-results {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.5rem;
}

.video-result {
    background-color: var(--bg-secondary);
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border-color);
    transition: all 0.2s ease;
}

.video-result:hover {
    border-color: var(--accent-primary);
    box-shadow: 0 4px 20px var(--shadow-color);
    transform: translateY(-2px);
}

.video-thumbnail-link {
    display: block;
    text-decoration: none;
}

.video-thumbnail-container {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    background-color: var(--bg-tertiary);
    overflow: hidden;
}

.video-thumbnail {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.video-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    color: var(--text-muted);
    background-color: var(--bg-tertiary);
}

.video-play-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60px;
    height: 60px;
    background-color: rgba(0, 0, 0, 0.7);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.video-result:hover .video-play-overlay {
    opacity: 1;
}

.video-play-overlay .play-icon {
    width: 28px;
    height: 28px;
    color: white;
    margin-left: 4px;
}

.video-duration {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background-color: rgba(0, 0, 0, 0.85);
    color: white;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.02em;
}

.video-info {
    padding: 0.875rem;
}

.video-title {
    margin: 0 0 0.5rem 0;
    font-size: 0.95rem;
    font-weight: 500;
    line-height: 1.4;
}

.video-title a {
    color: var(--text-primary);
    text-decoration: none;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.video-title a:hover {
    color: var(--accent-primary);
}

.video-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    font-size: 0.8rem;
    color: var(--text-muted);
}

.video-meta span {
    display: inline-flex;
    align-items: center;
}

.video-meta span:not(:last-child)::after {
    content: "\00B7";
    margin-left: 0.5rem;
    color: var(--text-muted);
}

.video-engine {
    text-transform: capitalize;
}

.video-description {
    margin: 0.5rem 0 0 0;
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    font-size: 0.9rem;
    font-weight: 500;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
}

.btn-primary {
    background-color: var(--accent-primary);
    border: none;
    color: white;
}

.btn-primary:hover {
    background-color: var(--accent-secondary);
    color: white;
    text-decoration: none;
}

.btn-secondary {
    background-color: transparent;
    border: 2px solid var(--border-color);
    color: var(--text-primary);
}

.btn-secondary:hover {
    border-color: var(--accent-primary);
    color: var(--accent-primary);
    text-decoration: none;
}

/* Forms */
.form-group {
    margin-bottom: 1rem;
}

.form-label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 500;
    color: var(--text-primary);
}

.form-input,
.form-textarea,
.form-select {
    width: 100%;
    padding: 0.75rem 1rem;
    font-size: 1rem;
    background-color: var(--input-bg);
    border: 1px solid var(--input-border);
    border-radius: 8px;
    color: var(--text-primary);
    transition: border-color 0.2s ease;
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
    outline: none;
    border-color: var(--input-focus);
}

.form-textarea {
    min-height: 150px;
    resize: vertical;
}

/* Cards */
.card {
    background-color: var(--bg-secondary);
    border-radius: 12px;
    padding: 1.5rem;
    border: 1px solid var(--border-color);
}

.card-title {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 1rem;
    color: var(--text-primary);
}

/* Info Pages */
.info-page {
    max-width: 800px;
    margin: 2rem auto;
    padding: 0 1rem;
}

.info-page h1 {
    color: var(--accent-primary);
    margin-bottom: 1.5rem;
}

.info-page h2 {
    color: var(--text-primary);
    margin: 2rem 0 1rem;
}

.info-page p {
    margin-bottom: 1rem;
    color: var(--text-secondary);
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .nav-container {
        flex-wrap: wrap;
    }

    .header-search {
        order: 3;
        max-width: 100%;
        width: 100%;
        margin-top: 0.5rem;
    }

    .nav-links {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background-color: var(--bg-secondary);
        flex-direction: column;
        padding: 1rem;
        border-bottom: 1px solid var(--border-color);
    }

    .nav-links.active {
        display: flex;
    }

    /* Search Results Mobile */
    .search-results-page {
        padding: 0.75rem;
    }

    .search-categories {
        gap: 0.35rem;
        padding: 0.5rem 0;
    }

    .category-link {
        padding: 0.4rem 0.75rem;
        font-size: 0.85rem;
    }

    .result-item {
        padding: 1rem;
        gap: 0.75rem;
    }

    .result-item:hover {
        transform: none;
    }

    .result-favicon {
        width: 28px;
        height: 28px;
    }

    .result-title {
        font-size: 1rem;
    }

    .result-description {
        -webkit-line-clamp: 2;
    }

    .image-results {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.75rem;
    }

    .image-result img {
        height: 120px;
    }

    .image-placeholder {
        height: 120px;
        font-size: 2rem;
    }

    .video-results {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .video-play-overlay {
        width: 50px;
        height: 50px;
    }

    .video-play-overlay .play-icon {
        width: 24px;
        height: 24px;
    }

    .video-title {
        font-size: 0.9rem;
    }

    .video-meta {
        font-size: 0.75rem;
    }

    .video-description {
        font-size: 0.8rem;
        -webkit-line-clamp: 2;
    }

    .pagination {
        flex-wrap: wrap;
        gap: 0.75rem;
    }

    .page-link {
        padding: 0.6rem 1rem;
        font-size: 0.9rem;
    }

    /* Mobile: show hamburger, hide nav-links per AI.md PART 16 */
    .nav-toggle {
        display: flex;
        margin-left: auto;
    }

    .nav-links {
        display: none;
    }

    .home-container {
        min-height: calc(100vh - 250px);
    }

    .category-tab {
        padding: 0.5rem 0.75rem;
        min-width: 60px;
    }

    .tab-icon {
        font-size: 1rem;
    }

    .tab-text {
        font-size: 0.65rem;
    }

    .home-features {
        gap: 1rem;
    }
}

@media (max-width: 480px) {
    .search-input {
        padding: 0.75rem 1rem;
    }

    .search-btn {
        padding: 0.75rem 1rem;
    }

    .category-tabs {
        gap: 0.25rem;
    }

    .category-tab {
        padding: 0.5rem;
        min-width: 50px;
    }
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Focus styles */
:focus-visible {
    outline: 2px solid var(--accent-primary);
    outline-offset: 2px;
}

/* Print styles - Per AI.md PART 14: Print-friendly styles */
@media print {
    /* Hide non-essential elements */
    .site-header,
    .site-footer,
    .nav-toggle,
    .nav-panel,
    .nav-overlay,
    .theme-toggle,
    .cookie-consent,
    .announcement,
    .btn,
    button:not([type="submit"]),
    .search-form,
    .pagination,
    .modal,
    .toast-container {
        display: none !important;
    }

    /* Reset colors for print */
    body {
        background: white !important;
        color: black !important;
        font-size: 12pt;
        line-height: 1.5;
    }

    /* Ensure links are visible */
    a {
        color: black !important;
        text-decoration: underline;
    }

    /* Show URL after links */
    a[href^="http"]:after {
        content: " (" attr(href) ")";
        font-size: 0.8em;
        color: #666;
    }

    /* Don't break inside important elements */
    .result-item,
    .widget,
    table tr {
        page-break-inside: avoid;
    }

    /* Ensure tables print properly */
    table {
        border-collapse: collapse;
    }

    table th,
    table td {
        border: 1px solid #ccc;
        padding: 0.5em;
    }

    /* Print headings clearly */
    h1, h2, h3, h4, h5, h6 {
        color: black !important;
        page-break-after: avoid;
    }

    /* Ensure images don't overflow */
    img {
        max-width: 100% !important;
    }
}

/* ========== WIDGET SYSTEM ========== */

.widgets-section {
    width: 100%;
    max-width: 900px;
    margin: 2rem auto;
    padding: 0 1rem;
}

.widget-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1rem;
}

.widget {
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    overflow: hidden;
    transition: box-shadow 0.2s ease;
}

.widget:hover {
    box-shadow: 0 4px 12px var(--shadow-color);
}

.widget-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    background-color: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-color);
    position: relative;
}

.widget-title {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--text-primary);
}

.widget-menu {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 0.25rem 0.5rem;
    font-size: 1.2rem;
    border-radius: 4px;
    transition: background-color 0.2s;
}

.widget-menu:hover {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
}

.widget-content {
    padding: 1rem;
    min-height: 120px;
}

.widget-loading {
    color: var(--text-muted);
    text-align: center;
    padding: 2rem;
    font-size: 0.9rem;
}

.widget-placeholder {
    text-align: center;
    padding: 1rem;
    color: var(--text-muted);
}

.widget-placeholder-icon {
    font-size: 2rem;
    margin-bottom: 0.5rem;
}

.widget-placeholder-text {
    font-size: 0.85rem;
    margin-bottom: 0.75rem;
}

.widget-settings-btn,
.widget-add-btn {
    background-color: var(--accent-primary);
    color: var(--bg-primary);
    border: none;
    padding: 0.5rem 1rem;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.85rem;
    transition: opacity 0.2s;
}

.widget-settings-btn:hover,
.widget-add-btn:hover {
    opacity: 0.9;
}

/* Widget Dropdown Menu */
.widget-dropdown-menu {
    position: absolute;
    top: 100%;
    right: 0;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 4px 12px var(--shadow-color);
    z-index: 100;
    min-width: 120px;
    overflow: hidden;
}

.widget-dropdown-menu button {
    display: block;
    width: 100%;
    padding: 0.75rem 1rem;
    border: none;
    background: none;
    color: var(--text-primary);
    text-align: left;
    cursor: pointer;
    font-size: 0.85rem;
}

.widget-dropdown-menu button:hover {
    background-color: var(--bg-tertiary);
}

.widget-dropdown-menu button.danger {
    color: var(--accent-error);
}

/* Widget Drag and Drop */
.widget[draggable="true"] {
    cursor: grab;
}

.widget[draggable="true"]:active {
    cursor: grabbing;
}

.widget.widget-dragging {
    opacity: 0.6;
    cursor: grabbing;
}

.widget.widget-dragging-active {
    opacity: 0.4;
    transform: scale(0.98);
    box-shadow: 0 8px 24px var(--shadow-color);
}

.widget-placeholder-drop {
    background: var(--bg-tertiary);
    border: 2px dashed var(--accent-primary);
    border-radius: 12px;
    min-height: 150px;
    opacity: 0.6;
    transition: opacity 0.2s ease;
}

.widget-placeholder-drop:empty::before {
    content: 'Drop here';
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    min-height: 150px;
    color: var(--text-muted);
    font-size: 0.9rem;
}

/* Prevent text selection during drag */
.widget-grid.dragging-active {
    user-select: none;
}

/* Widget Settings Modal */
.widget-settings-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
}

.widget-settings-content {
    background: var(--bg-secondary);
    border-radius: 12px;
    padding: 1.5rem;
    max-width: 400px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
}

.widget-settings-content h3 {
    margin: 0 0 1rem 0;
    font-size: 1.1rem;
    color: var(--text-primary);
}

.widget-settings-content label {
    display: block;
    margin-bottom: 1rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.widget-settings-content input,
.widget-settings-content select,
.widget-settings-content textarea {
    display: block;
    width: 100%;
    padding: 0.5rem;
    margin-top: 0.25rem;
    background: var(--input-bg);
    border: 1px solid var(--input-border);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.9rem;
}

.widget-settings-content textarea {
    resize: vertical;
    min-height: 80px;
}

.widget-settings-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    margin-top: 1rem;
}

.widget-settings-actions button {
    padding: 0.5rem 1rem;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.9rem;
}

.widget-settings-actions button:first-child {
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

.widget-settings-actions button:last-child {
    background: var(--accent-primary);
    border: none;
    color: var(--bg-primary);
}

/* Clock Widget */
.clock-widget {
    text-align: center;
    padding: 0.5rem;
}

.clock-time {
    font-size: 2.5rem;
    font-weight: 700;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    color: var(--accent-primary);
    letter-spacing: -1px;
}

.clock-date {
    color: var(--text-secondary);
    font-size: 0.9rem;
    margin-top: 0.5rem;
}

/* Weather Widget */
.weather-widget {
    display: flex;
    gap: 1rem;
    align-items: center;
}

.weather-main {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 80px;
}

.weather-icon {
    font-size: 2.5rem;
    line-height: 1;
}

.weather-temp {
    font-size: 2rem;
    font-weight: 700;
    color: var(--accent-primary);
}

.weather-details {
    flex: 1;
}

.weather-location {
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.weather-description {
    color: var(--text-secondary);
    font-size: 0.9rem;
    text-transform: capitalize;
}

.weather-extra {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin-top: 0.5rem;
}

/* Quick Links Widget */
.quicklinks-widget {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.5rem;
}

.quicklink-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0.75rem 0.5rem;
    border-radius: 8px;
    text-decoration: none;
    color: var(--text-primary);
    transition: background-color 0.2s;
}

.quicklink-item:hover {
    background-color: var(--bg-tertiary);
}

.quicklink-favicon {
    width: 24px;
    height: 24px;
    margin-bottom: 0.5rem;
    border-radius: 4px;
}

.quicklink-name {
    font-size: 0.75rem;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
    color: var(--text-secondary);
}

.quicklink-add {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--text-muted);
    background: none;
    border: 2px dashed var(--border-color);
    border-radius: 8px;
    cursor: pointer;
    min-height: 60px;
    transition: border-color 0.2s, color 0.2s;
}

.quicklink-add:hover {
    border-color: var(--accent-primary);
    color: var(--accent-primary);
}

/* Calculator Widget */
.calculator-widget {
    max-width: 220px;
    margin: 0 auto;
}

.calc-display {
    width: 100%;
    padding: 0.75rem;
    font-size: 1.5rem;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    text-align: right;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    margin-bottom: 0.5rem;
}

.calc-buttons {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.25rem;
}

.calc-buttons button {
    padding: 0.75rem;
    font-size: 1.1rem;
    border: none;
    border-radius: 6px;
    background: var(--bg-tertiary);
    color: var(--text-primary);
    cursor: pointer;
    transition: background-color 0.2s;
}

.calc-buttons button:hover {
    background: var(--accent-primary);
    color: var(--bg-primary);
}

.calc-buttons button.calc-op {
    background: var(--accent-secondary);
    color: var(--bg-primary);
}

.calc-buttons button.calc-eq {
    background: var(--accent-success);
    color: var(--bg-primary);
}

.calc-buttons button.calc-clear {
    background: var(--accent-error);
    color: white;
    grid-column: span 4;
}

/* Notes Widget */
.notes-widget {
    height: 100%;
}

.notes-textarea {
    width: 100%;
    height: 120px;
    resize: vertical;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 0.75rem;
    color: var(--text-primary);
    font-family: inherit;
    font-size: 0.9rem;
    line-height: 1.5;
}

.notes-textarea:focus {
    outline: none;
    border-color: var(--accent-primary);
}

/* Calendar Widget */
.calendar-widget {
    font-size: 0.85rem;
}

.calendar-header {
    text-align: center;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.75rem;
}

.calendar-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    color: var(--text-muted);
    font-size: 0.75rem;
    margin-bottom: 0.5rem;
}

.calendar-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    gap: 2px;
}

.calendar-day {
    padding: 0.35rem;
    border-radius: 4px;
    color: var(--text-secondary);
}

.calendar-day.empty {
    visibility: hidden;
}

.calendar-day.today {
    background: var(--accent-primary);
    color: var(--bg-primary);
    font-weight: 600;
}

/* Converter Widget */
.converter-widget select,
.converter-widget input {
    padding: 0.5rem;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.9rem;
}

.converter-widget > select {
    width: 100%;
    margin-bottom: 0.75rem;
}

.converter-row {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.converter-row input {
    flex: 1;
    min-width: 0;
}

.converter-row select {
    width: 80px;
}

.converter-equals {
    text-align: center;
    color: var(--text-muted);
    font-size: 1.2rem;
    margin: 0.25rem 0;
}

/* News Widget */
.news-widget {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.news-item {
    display: block;
    padding: 0.5rem;
    border-radius: 6px;
    text-decoration: none;
    transition: background-color 0.2s;
}

.news-item:hover {
    background-color: var(--bg-tertiary);
}

.news-title {
    color: var(--text-primary);
    font-size: 0.85rem;
    line-height: 1.3;
    margin-bottom: 0.25rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.news-source {
    color: var(--text-muted);
    font-size: 0.75rem;
}

/* Stocks Widget */
.stocks-widget {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.stock-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem;
    background: var(--bg-tertiary);
    border-radius: 6px;
}

.stock-symbol {
    font-weight: 600;
    color: var(--text-primary);
}

.stock-price {
    color: var(--text-secondary);
    font-family: 'SF Mono', 'Monaco', monospace;
}

.stock-change {
    font-size: 0.85rem;
    font-weight: 500;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
}

.stock-change.positive {
    background: rgba(80, 250, 123, 0.2);
    color: var(--accent-success);
}

.stock-change.negative {
    background: rgba(255, 85, 85, 0.2);
    color: var(--accent-error);
}

/* Crypto Widget */
.crypto-widget {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.crypto-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem;
    background: var(--bg-tertiary);
    border-radius: 6px;
}

.crypto-name {
    font-weight: 600;
    color: var(--text-primary);
    text-transform: capitalize;
}

.crypto-price {
    color: var(--text-secondary);
    font-family: 'SF Mono', 'Monaco', monospace;
    font-size: 0.9rem;
}

.crypto-change {
    font-size: 0.85rem;
    font-weight: 500;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
}

.crypto-change.positive {
    background: rgba(80, 250, 123, 0.2);
    color: var(--accent-success);
}

.crypto-change.negative {
    background: rgba(255, 85, 85, 0.2);
    color: var(--accent-error);
}

/* Sports Widget */
.sports-widget {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.sports-game {
    padding: 0.5rem;
    background: var(--bg-tertiary);
    border-radius: 6px;
    text-align: center;
}

.sports-teams {
    font-size: 0.85rem;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.sports-vs {
    color: var(--text-muted);
    margin: 0 0.5rem;
}

.sports-score {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--accent-primary);
}

.sports-status {
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-top: 0.25rem;
}

/* RSS Widget */
.rss-widget {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.rss-item {
    display: block;
    padding: 0.5rem;
    border-radius: 6px;
    text-decoration: none;
    transition: background-color 0.2s;
}

.rss-item:hover {
    background-color: var(--bg-tertiary);
}

.rss-title {
    color: var(--text-primary);
    font-size: 0.85rem;
    line-height: 1.3;
    margin-bottom: 0.25rem;
}

.rss-source {
    color: var(--text-muted);
    font-size: 0.75rem;
}

/* Widget Responsive */
@media (max-width: 768px) {
    .widget-grid {
        grid-template-columns: 1fr;
    }

    .quicklinks-widget {
        grid-template-columns: repeat(4, 1fr);
    }

    .clock-time {
        font-size: 2rem;
    }
}

@media (max-width: 480px) {
    .widgets-section {
        padding: 0 0.5rem;
    }

    .widget-content {
        padding: 0.75rem;
    }

    .quicklinks-widget {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Toast Notifications (per AI.md PART 17)
 * Position: top-right, stacked vertically
 * Types: success, error, warning, info
 */
#toast-container {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-width: 400px;
    pointer-events: none;
}

.toast {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.875rem 1rem;
    border-radius: 0.5rem;
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 12px var(--shadow-color);
    transform: translateX(100%);
    opacity: 0;
    transition: transform 0.3s ease, opacity 0.3s ease;
    pointer-events: auto;
}

.toast-visible {
    transform: translateX(0);
    opacity: 1;
}

.toast-hiding {
    transform: translateX(100%);
    opacity: 0;
}

.toast-icon {
    flex-shrink: 0;
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: bold;
    border-radius: 50%;
}

.toast-success .toast-icon {
    background-color: var(--accent-success);
    color: #fff;
}

.toast-error .toast-icon {
    background-color: var(--accent-error);
    color: #fff;
}

.toast-warning .toast-icon {
    background-color: var(--accent-warning);
    color: #282a36;
}

.toast-info .toast-icon {
    background-color: var(--accent-info);
    color: #282a36;
}

.toast-message {
    flex: 1;
    font-size: 0.9rem;
    line-height: 1.4;
    color: var(--text-primary);
}

.toast-close {
    flex-shrink: 0;
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-muted);
    font-size: 1.25rem;
    line-height: 1;
    padding: 0;
    transition: color 0.2s ease;
}

.toast-close:hover {
    color: var(--text-primary);
}

/* Confirmation Dialog (per AI.md PART 17)
 * Uses native <dialog> with accessibility
 */
#confirm-dialog {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 400px;
    width: 90%;
    padding: 0;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background-color: var(--bg-secondary);
    box-shadow: 0 8px 32px var(--shadow-color);
}

#confirm-dialog::backdrop {
    background-color: rgba(0, 0, 0, 0.5);
}

#confirm-dialog header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border-color);
}

#confirm-dialog h2 {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
}

#confirm-dialog main {
    padding: 1.25rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

#confirm-dialog footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--border-color);
    background-color: var(--bg-tertiary);
}

/* Prompt Dialog (per AI.md PART 17)
 * Uses native <dialog> for text input prompts
 */
#prompt-dialog {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 400px;
    width: 90%;
    padding: 0;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background-color: var(--bg-secondary);
    box-shadow: 0 8px 32px var(--shadow-color);
}

#prompt-dialog::backdrop {
    background-color: rgba(0, 0, 0, 0.5);
}

#prompt-dialog form {
    display: flex;
    flex-direction: column;
}

#prompt-dialog label {
    padding: 1.25rem 1.25rem 0.5rem;
    font-size: 1rem;
    font-weight: 500;
    color: var(--text-primary);
}

#prompt-dialog input {
    margin: 0 1.25rem;
    padding: 0.75rem;
    font-size: 1rem;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background-color: var(--bg-tertiary);
    color: var(--text-primary);
}

#prompt-dialog input:focus {
    outline: none;
    border-color: var(--accent-primary);
    box-shadow: 0 0 0 3px var(--focus-ring);
}

#prompt-dialog footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1.25rem;
    margin-top: 0.5rem;
    border-top: 1px solid var(--border-color);
    background-color: var(--bg-tertiary);
}

/* Alert Dialog (per AI.md PART 17) */
#alert-dialog {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 400px;
    width: 90%;
    padding: 0;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background-color: var(--bg-secondary);
    box-shadow: 0 8px 32px var(--shadow-color);
}

#alert-dialog::backdrop {
    background-color: rgba(0, 0, 0, 0.5);
}

#alert-dialog header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border-color);
}

#alert-dialog h2 {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
}

#alert-dialog main {
    padding: 1.25rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

#alert-dialog footer {
    display: flex;
    justify-content: flex-end;
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--border-color);
    background-color: var(--bg-tertiary);
}

/* Mobile adjustments for toasts */
@media (max-width: 480px) {
    #toast-container {
        left: 0.5rem;
        right: 0.5rem;
        max-width: none;
    }

    .toast {
        transform: translateY(-100%);
    }

    .toast-visible {
        transform: translateY(0);
    }

    .toast-hiding {
        transform: translateY(-100%);
    }

    #confirm-dialog {
        width: 95%;
    }

    #prompt-dialog {
        width: 95%;
    }

    #alert-dialog {
        width: 95%;
    }
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

/* Visibility */
.hidden {
    display: none !important;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Skip link for keyboard navigation - WCAG 2.1 AA */
.skip-link {
    position: absolute;
    top: -40px;
    left: 0;
    background: var(--accent-primary);
    color: var(--bg-primary);
    padding: 8px 16px;
    z-index: 10000;
    text-decoration: none;
    font-weight: 600;
    border-radius: 0 0 4px 0;
    transition: top 0.2s;
}

.skip-link:focus {
    top: 0;
    outline: 2px solid var(--text-primary);
    outline-offset: 2px;
}

/* Spacing */
.mt-1 {
    margin-top: 1rem;
}

/* Bang Suggestion Styles */
.bang-suggestion-item {
    padding: 8px 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
}

.bang-suggestion-item:hover {
    background: var(--bg-tertiary, #313244);
}

.bang-shortcut {
    font-family: monospace;
    color: var(--accent-color, #bd93f9);
    font-weight: bold;
}

/* ============================================================================
   SEARCH AUTOCOMPLETE STYLES
   ============================================================================ */

.autocomplete-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-top: none;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 4px 12px var(--shadow-color);
    z-index: 1000;
    max-height: 400px;
    overflow-y: auto;
}

.autocomplete-item {
    display: flex;
    align-items: center;
    padding: 10px 16px;
    cursor: pointer;
    transition: background-color 0.15s ease;
    gap: 12px;
}

.autocomplete-item:hover,
.autocomplete-item.selected {
    background: var(--bg-tertiary);
}

.autocomplete-item.selected {
    background: var(--accent-primary);
    color: var(--bg-primary);
}

.autocomplete-item.selected .autocomplete-icon {
    stroke: var(--bg-primary);
}

.autocomplete-item.selected .autocomplete-bang-shortcut {
    color: var(--bg-primary);
}

.autocomplete-item.selected .autocomplete-bang-category {
    color: var(--bg-primary);
    opacity: 0.8;
}

.autocomplete-icon {
    flex-shrink: 0;
    stroke: var(--text-muted);
}

.autocomplete-text {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Autocomplete Bang Styles */
.autocomplete-bang {
    display: flex;
    align-items: center;
    gap: 8px;
}

.autocomplete-bang-shortcut {
    font-family: "SF Mono", Monaco, Consolas, monospace;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--accent-primary);
    min-width: 50px;
}

.autocomplete-bang-name {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.autocomplete-bang-category {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: capitalize;
    padding: 2px 8px;
    background: var(--bg-tertiary);
    border-radius: 4px;
}

/* Scrollbar styling for autocomplete dropdown */
.autocomplete-dropdown::-webkit-scrollbar {
    width: 8px;
}

.autocomplete-dropdown::-webkit-scrollbar-track {
    background: var(--bg-secondary);
}

.autocomplete-dropdown::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 4px;
}

.autocomplete-dropdown::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

/* Mobile responsive adjustments */
@media (max-width: 768px) {
    .autocomplete-dropdown {
        max-height: 300px;
    }

    .autocomplete-item {
        padding: 12px 14px;
    }

    .autocomplete-bang-shortcut {
        min-width: 40px;
        font-size: 0.8rem;
    }

    .autocomplete-bang-category {
        display: none;
    }
}

/* ============================================================================
   KEYBOARD NAVIGATION STYLES
   ============================================================================ */

.keyboard-selected {
    outline: 2px solid var(--accent-primary);
    outline-offset: 2px;
    background: var(--bg-secondary);
    border-radius: 4px;
}

#keyboard-help-modal {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 0;
    max-width: 500px;
    width: 90%;
    color: var(--text-primary);
}

#keyboard-help-modal::backdrop {
    background: rgba(0, 0, 0, 0.5);
}

#keyboard-help-modal header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color);
}

#keyboard-help-modal h2 {
    margin: 0;
    font-size: 1.25rem;
}

.keyboard-help-content {
    padding: 20px;
    max-height: 60vh;
    overflow-y: auto;
}

.shortcut-group {
    margin-bottom: 20px;
}

.shortcut-group h3 {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0 0 10px 0;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.shortcut {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
}

.shortcut kbd {
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    padding: 2px 8px;
    font-family: monospace;
    font-size: 0.875rem;
    min-width: 24px;
    text-align: center;
    margin-right: 4px;
}

.shortcut span {
    color: var(--text-secondary);
}

#keyboard-help-modal footer {
    padding: 16px 20px;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
}

/* ============================================================================
   VIDEO PREVIEW STYLES
   ============================================================================ */

.video-preview-container {
    position: fixed;
    z-index: 9999;
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 8px 32px var(--shadow-color);
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0.2s;
}

.video-preview-container.visible {
    opacity: 1;
    visibility: visible;
}

.video-preview-youtube,
.video-preview-generic {
    position: relative;
    width: 100%;
    height: 100%;
}

.video-preview-thumb,
.video-preview-gif,
.video-preview-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.video-preview-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    background: var(--accent-primary);
    width: 0;
    transition: width 0.3s;
}

.video-preview-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 32px;
    color: white;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
    pointer-events: none;
}

.touch-scrub-indicator {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 4px;
    background: var(--accent-primary);
    transition: width 0.1s;
}

/* ============================================================================
   ADVANCED SEARCH MODAL STYLES
   ============================================================================ */

.advanced-search-modal {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 0;
    max-width: 600px;
    width: 95%;
    max-height: 90vh;
    color: var(--text-primary);
}

.advanced-search-modal::backdrop {
    background: rgba(0, 0, 0, 0.6);
}

.advanced-search-modal header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color);
}

.advanced-search-modal header h2 {
    margin: 0;
    font-size: 1.25rem;
}

.advanced-search-modal .close-btn {
    background: none;
    border: none;
    font-size: 24px;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0;
    line-height: 1;
}

.advanced-search-modal .close-btn:hover {
    color: var(--text-primary);
}

.advanced-search-content {
    padding: 20px;
    max-height: 60vh;
    overflow-y: auto;
}

.advanced-search-group {
    margin-bottom: 16px;
}

.advanced-search-group label {
    display: block;
    margin-bottom: 6px;
    font-weight: 500;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.advanced-search-group input,
.advanced-search-group select,
.advanced-search-group textarea {
    width: 100%;
    padding: 10px 12px;
    background: var(--input-bg);
    border: 1px solid var(--input-border);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 1rem;
}

.advanced-search-group input:focus,
.advanced-search-group select:focus,
.advanced-search-group textarea:focus {
    outline: none;
    border-color: var(--input-focus);
    box-shadow: 0 0 0 3px rgba(189, 147, 249, 0.2);
}

.advanced-search-row {
    display: flex;
    gap: 16px;
}

.advanced-search-group.half {
    flex: 1;
}

.advanced-search-preview {
    background: var(--bg-tertiary);
    border-radius: 6px;
    padding: 12px;
    margin-top: 16px;
}

.advanced-search-preview label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: var(--text-secondary);
    font-size: 0.75rem;
    text-transform: uppercase;
}

.advanced-search-preview code {
    display: block;
    font-family: monospace;
    color: var(--accent-info);
    word-break: break-all;
}

.advanced-search-modal footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 16px 20px;
    border-top: 1px solid var(--border-color);
}

.advanced-search-trigger {
    background: var(--bg-tertiary);
    border: none;
    border-left: 1px solid var(--border-color);
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0 1rem;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s, color 0.2s;
}

.advanced-search-trigger:hover {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

/* Advanced search trigger in nav search (smaller) */
.nav-search-form .advanced-search-trigger {
    padding: 0 0.5rem;
    font-size: 14px;
}

/* ============================================================================
   RELATED SEARCHES STYLES
   ============================================================================ */

.related-searches {
    margin: 32px 0;
    padding: 20px;
    background: var(--bg-secondary);
    border-radius: 8px;
}

.related-title {
    font-size: 1rem;
    margin: 0 0 16px 0;
    color: var(--text-secondary);
}

.related-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.related-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    color: var(--text-primary);
    text-decoration: none;
    font-size: 0.875rem;
    transition: all 0.2s;
}

.related-item:hover {
    background: var(--accent-primary);
    border-color: var(--accent-primary);
    color: var(--bg-primary);
}

.related-icon {
    flex-shrink: 0;
    opacity: 0.6;
}

.related-item:hover .related-icon {
    opacity: 1;
}

/* People Also Ask */
.people-also-ask {
    margin: 24px 0;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
}

.paa-title {
    padding: 16px;
    margin: 0;
    font-size: 1rem;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
}

.paa-item {
    border-bottom: 1px solid var(--border-color);
}

.paa-item:last-child {
    border-bottom: none;
}

.paa-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px;
    cursor: pointer;
    list-style: none;
}

.paa-question::-webkit-details-marker {
    display: none;
}

.paa-question:hover {
    background: var(--bg-secondary);
}

.paa-arrow {
    transition: transform 0.2s;
    flex-shrink: 0;
}

.paa-item[open] .paa-arrow {
    transform: rotate(180deg);
}

.paa-answer {
    padding: 0 16px 16px;
    color: var(--text-secondary);
}

.paa-link {
    display: inline-block;
    margin-top: 8px;
    color: var(--link-color);
    text-decoration: none;
}

.paa-link:hover {
    text-decoration: underline;
}

/* ============================================================================
   WIDGET STYLES (New Widgets)
   ============================================================================ */

/* Currency Widget */
.currency-widget {
    padding: 16px;
}

.currency-row {
    display: flex;
    gap: 8px;
    margin-bottom: 8px;
}

.currency-row input {
    flex: 1;
    min-width: 0;
}

.currency-row select {
    width: 80px;
}

.currency-equals {
    text-align: center;
    font-size: 1.25rem;
    color: var(--text-secondary);
    margin: 8px 0;
}

.currency-convert-btn {
    width: 100%;
    padding: 10px;
    background: var(--accent-primary);
    color: var(--bg-primary);
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-weight: 500;
}

/* Timezone Widget */
.timezone-widget {
    padding: 12px;
}

.timezone-item {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid var(--border-color);
}

.timezone-item:last-child {
    border-bottom: none;
}

.timezone-city {
    font-weight: 500;
}

.timezone-time {
    font-family: monospace;
    color: var(--accent-info);
}

/* Translate Widget */
.translate-widget {
    padding: 16px;
}

.translate-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}

.translate-row select {
    flex: 1;
}

.translate-arrow {
    color: var(--text-secondary);
}

.translate-widget textarea {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--input-bg);
    color: var(--text-primary);
    resize: vertical;
    min-height: 80px;
}

.translate-output {
    margin-top: 12px;
    padding: 12px;
    background: var(--bg-tertiary);
    border-radius: 6px;
    min-height: 60px;
    color: var(--text-primary);
}

/* Wikipedia Widget */
.wikipedia-widget {
    padding: 16px;
}

.wikipedia-widget input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--input-bg);
    color: var(--text-primary);
    margin-bottom: 12px;
}

.wiki-result {
    display: flex;
    gap: 12px;
}

.wiki-thumb {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 6px;
    flex-shrink: 0;
}

.wiki-content {
    flex: 1;
    min-width: 0;
}

.wiki-title {
    margin: 0 0 8px 0;
    font-size: 1rem;
}

.wiki-extract {
    margin: 0 0 8px 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
    line-height: 1.4;
}

.wiki-link {
    font-size: 0.875rem;
    color: var(--link-color);
}

.wiki-placeholder {
    color: var(--text-secondary);
    text-align: center;
    padding: 20px;
}

/* Tracking Widget */
.tracking-widget {
    padding: 16px;
}

.tracking-input-row {
    display: flex;
    gap: 8px;
}

.tracking-input-row input {
    flex: 1;
    padding: 10px 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--input-bg);
    color: var(--text-primary);
}

.tracking-input-row button {
    padding: 10px 16px;
    background: var(--accent-primary);
    color: var(--bg-primary);
    border: none;
    border-radius: 6px;
    cursor: pointer;
}

.tracking-placeholder {
    margin-top: 12px;
    padding: 16px;
    text-align: center;
    color: var(--text-secondary);
    background: var(--bg-tertiary);
    border-radius: 6px;
}

/* Nutrition Widget */
.nutrition-widget {
    padding: 16px;
}

.nutrition-widget input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--input-bg);
    color: var(--text-primary);
    margin-bottom: 12px;
}

.nutrition-result {
    background: var(--bg-tertiary);
    border-radius: 6px;
    padding: 12px;
}

.nutrition-name {
    margin: 0 0 4px 0;
    font-size: 1rem;
}

.nutrition-serving {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 12px;
}

.nutrition-facts {
    border-top: 1px solid var(--border-color);
    padding-top: 12px;
}

.nutrition-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.875rem;
}

/* QR Code Widget */
.qrcode-widget {
    padding: 16px;
    text-align: center;
}

.qrcode-widget input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--input-bg);
    color: var(--text-primary);
    margin-bottom: 12px;
}

.qr-canvas {
    width: 150px;
    height: 150px;
    margin: 0 auto 12px;
    background: white;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.qr-placeholder {
    color: #666;
    font-size: 0.75rem;
    padding: 20px;
}

/* Timer Widget */
.timer-widget {
    padding: 16px;
    text-align: center;
}

.timer-display {
    font-family: monospace;
    font-size: 2.5rem;
    margin-bottom: 16px;
    color: var(--accent-info);
}

.timer-buttons {
    display: flex;
    gap: 8px;
    justify-content: center;
    margin-bottom: 16px;
}

.timer-buttons button {
    padding: 8px 16px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--bg-secondary);
    color: var(--text-primary);
    cursor: pointer;
}

.timer-buttons button:hover {
    background: var(--bg-tertiary);
}

.timer-presets {
    display: flex;
    gap: 8px;
    justify-content: center;
    flex-wrap: wrap;
}

.timer-presets button {
    padding: 4px 12px;
    font-size: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    background: var(--bg-tertiary);
    color: var(--text-secondary);
    cursor: pointer;
}

.timer-presets button:hover {
    color: var(--text-primary);
}

/* Lorem Ipsum Widget */
.lorem-widget {
    padding: 16px;
}

.lorem-options {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.lorem-options select,
.lorem-options input {
    padding: 8px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--input-bg);
    color: var(--text-primary);
}

.lorem-options input {
    width: 60px;
}

.lorem-options button {
    padding: 8px 16px;
    background: var(--accent-primary);
    color: var(--bg-primary);
    border: none;
    border-radius: 6px;
    cursor: pointer;
}

.lorem-output {
    padding: 12px;
    background: var(--bg-tertiary);
    border-radius: 6px;
    font-size: 0.875rem;
    line-height: 1.5;
    max-height: 150px;
    overflow-y: auto;
    margin-bottom: 12px;
}

.lorem-copy {
    width: 100%;
    padding: 8px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    cursor: pointer;
}

/* Dictionary Widget */
.dictionary-widget {
    padding: 16px;
}

.dictionary-widget input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--input-bg);
    color: var(--text-primary);
    margin-bottom: 12px;
}

.dict-result {
    background: var(--bg-tertiary);
    border-radius: 6px;
    padding: 12px;
}

.dict-word {
    margin: 0;
    font-size: 1.25rem;
}

.dict-phonetic {
    color: var(--text-secondary);
    font-style: italic;
    margin-left: 8px;
}

.dict-meaning {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--border-color);
}

.dict-pos {
    display: inline-block;
    background: var(--accent-primary);
    color: var(--bg-primary);
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 500;
    margin-bottom: 8px;
}

.dict-def {
    margin: 8px 0;
    font-size: 0.875rem;
}

.dict-example {
    margin: 4px 0 8px;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    font-style: italic;
}

.dict-placeholder {
    color: var(--text-secondary);
    text-align: center;
    padding: 20px;
}

/* IP Address Widget */
.ip-widget {
    padding: 24px;
    text-align: center;
}

.ip-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

.ip-value {
    font-family: monospace;
    font-size: 1.5rem;
    color: var(--accent-info);
    margin-bottom: 16px;
}

.ip-copy {
    padding: 8px 24px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    cursor: pointer;
}

.ip-error {
    color: var(--accent-error);
}

/* Color Picker Widget */
.colorpicker-widget {
    padding: 16px;
}

.colorpicker-widget input[type="color"] {
    width: 100%;
    height: 60px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    margin-bottom: 12px;
}

.color-values {
    margin-bottom: 12px;
}

.color-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.color-row label {
    width: 40px;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.color-row input {
    flex: 1;
    padding: 8px;
    font-family: monospace;
    font-size: 0.875rem;
    border: 1px solid var(--border-color);
    border-radius: 4px;
    background: var(--input-bg);
    color: var(--text-primary);
}

.colorpicker-widget button {
    width: 100%;
    padding: 8px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    cursor: pointer;
}

/* ============================================================================
   RESPONSIVE ADJUSTMENTS FOR NEW COMPONENTS
   ============================================================================ */

@media (max-width: 768px) {
    .advanced-search-row {
        flex-direction: column;
    }

    .advanced-search-modal {
        max-height: 95vh;
    }

    .related-list {
        flex-direction: column;
    }

    .related-item {
        justify-content: flex-start;
    }

    .video-preview-container {
        display: none !important;
    }

    .keyboard-help-content {
        max-height: 50vh;
    }
}

/* ============================================================================
   RTL (Right-to-Left) SUPPORT
   Per AI.md PART 31: CSS logical properties for RTL languages
   Supports: Arabic (ar), Hebrew (he), Persian (fa), Urdu (ur)
   ============================================================================ */

/* Use CSS logical properties for RTL-aware layouts */
[dir="rtl"] {
    /* Text alignment - use logical values */
    text-align: start;
}

/* Search input RTL adjustments */
[dir="rtl"] .search-input {
    text-align: start;
}

[dir="rtl"] .header-search-input {
    border-radius: 0 20px 20px 0;
    border-right: 1px solid var(--input-border);
    border-left: none;
}

[dir="rtl"] .header-search-btn {
    border-radius: 20px 0 0 20px;
}

/* Navigation RTL */
[dir="rtl"] .nav-toggle {
    margin-left: 0;
    margin-right: auto;
    margin-inline-start: auto;
    margin-inline-end: 0;
}

/* Result items RTL */
[dir="rtl"] .result-item {
    flex-direction: row-reverse;
}

[dir="rtl"] .result-meta {
    flex-direction: row-reverse;
}

/* Skip link RTL */
[dir="rtl"] .skip-link {
    left: auto;
    right: 0;
    border-radius: 0 0 0 4px;
}

/* Toast container RTL */
[dir="rtl"] #toast-container {
    left: 1rem;
    right: auto;
}

[dir="rtl"] .toast {
    flex-direction: row-reverse;
    transform: translateX(-100%);
}

[dir="rtl"] .toast-visible {
    transform: translateX(0);
}

[dir="rtl"] .toast-hiding {
    transform: translateX(-100%);
}

/* Footer and form alignment */
[dir="rtl"] .footer-container {
    text-align: start;
}

[dir="rtl"] .form-label {
    text-align: start;
}

/* Widget adjustments for RTL */
[dir="rtl"] .widget-header {
    flex-direction: row-reverse;
}

[dir="rtl"] .widget-dropdown-menu {
    left: 0;
    right: auto;
}

[dir="rtl"] .widget-dropdown-menu button {
    text-align: start;
}

/* Search info RTL */
[dir="rtl"] .search-info {
    padding-left: 0;
    padding-right: 0.25rem;
    padding-inline-start: 0.25rem;
    padding-inline-end: 0;
}

/* Flash message RTL */
[dir="rtl"] .flash {
    flex-direction: row-reverse;
}

/* Instant answer RTL */
[dir="rtl"] .instant-answer-header {
    flex-direction: row-reverse;
}

/* Category tabs RTL - maintain LTR for horizontal scroll */
[dir="rtl"] .category-tabs {
    direction: ltr;
}

[dir="rtl"] .category-tabs .category-tab {
    direction: rtl;
}

/* Autocomplete RTL */
[dir="rtl"] .autocomplete-item {
    flex-direction: row-reverse;
}

[dir="rtl"] .autocomplete-bang {
    flex-direction: row-reverse;
}

[dir="rtl"] .autocomplete-bang-shortcut {
    text-align: left;
}

/* Search categories horizontal scroll */
[dir="rtl"] .search-categories {
    direction: ltr;
}

[dir="rtl"] .search-categories .category-link {
    direction: rtl;
}

/* Admin sidebar RTL */
[dir="rtl"] .admin-container {
    flex-direction: row-reverse;
}

/* Pagination RTL */
[dir="rtl"] .pagination {
    flex-direction: row-reverse;
}

/* Cookie consent RTL */
[dir="rtl"] .cookie-consent-content {
    flex-direction: row-reverse;
}

/* Announcement RTL */
[dir="rtl"] .announcement {
    flex-direction: row-reverse;
}

[dir="rtl"] .announcement-content {
    flex-direction: row-reverse;
}

/* Image results grid - maintain LTR for grid layout */
[dir="rtl"] .image-results {
    direction: ltr;
}

[dir="rtl"] .image-result {
    direction: rtl;
}

/* Video results grid - maintain LTR for grid layout */
[dir="rtl"] .video-results {
    direction: ltr;
}

[dir="rtl"] .video-result {
    direction: rtl;
}

[dir="rtl"] .video-duration {
    left: 8px;
    right: auto;
}

/* Result URL RTL */
[dir="rtl"] .result-url {
    flex-direction: row-reverse;
}

/* Related searches RTL */
[dir="rtl"] .related-item {
    flex-direction: row-reverse;
}

/* People Also Ask RTL */
[dir="rtl"] .paa-question {
    flex-direction: row-reverse;
}

/* Modal footer RTL */
[dir="rtl"] .widget-settings-actions {
    flex-direction: row-reverse;
}

[dir="rtl"] #confirm-dialog footer {
    flex-direction: row-reverse;
}

/* Advanced search modal RTL */
[dir="rtl"] .advanced-search-modal header {
    flex-direction: row-reverse;
}

[dir="rtl"] .advanced-search-modal footer {
    flex-direction: row-reverse;
}

/* Color preview margin RTL */
[dir="rtl"] .instant-answer-content .color-preview {
    margin-right: 0;
    margin-left: 0.5rem;
    margin-inline-start: 0;
    margin-inline-end: 0.5rem;
}

/* Mobile RTL adjustments */
@media (max-width: 768px) {
    [dir="rtl"] .nav-links {
        text-align: start;
    }
}

@media (max-width: 480px) {
    [dir="rtl"] #toast-container {
        left: 0.5rem;
        right: 0.5rem;
    }

    [dir="rtl"] .toast {
        transform: translateY(-100%);
    }

    [dir="rtl"] .toast-visible {
        transform: translateY(0);
    }

    [dir="rtl"] .toast-hiding {
        transform: translateY(-100%);
    }
}

/* ============================================================================
   STATIC PAGES (About, Privacy, Contact, Help, Terms)
   ============================================================================ */

.static-page {
    max-width: 900px;
    margin: 0 auto;
    padding: 2rem 1rem;
}

.static-page h1 {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    color: var(--text-primary);
    border-bottom: 2px solid var(--accent-primary);
    padding-bottom: 0.5rem;
}

.static-page h2 {
    font-size: 1.5rem;
    font-weight: 600;
    margin-top: 2rem;
    margin-bottom: 1rem;
    color: var(--text-primary);
}

.static-page h3 {
    font-size: 1.25rem;
    font-weight: 600;
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
    color: var(--text-secondary);
}

.static-page p {
    margin-bottom: 1rem;
    line-height: 1.7;
    color: var(--text-secondary);
}

.static-page ul, .static-page ol {
    margin-bottom: 1rem;
    padding-left: 1.5rem;
}

.static-page li {
    margin-bottom: 0.5rem;
    color: var(--text-secondary);
}

.static-page a {
    color: var(--link-color);
    text-decoration: underline;
}

.static-page a:hover {
    color: var(--link-hover);
}

.page-content {
    background: var(--bg-secondary);
    border-radius: 12px;
    padding: 2rem;
    box-shadow: 0 2px 8px var(--shadow-color);
}

.page-content.markdown {
    line-height: 1.8;
}

/* About Page */
.about-page .about-section {
    margin-bottom: 2rem;
}

.about-page .feature-list {
    list-style: none;
    padding: 0;
    display: grid;
    gap: 1rem;
}

.about-page .feature-list li {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem;
    background: var(--bg-tertiary);
    border-radius: 8px;
    margin-bottom: 0;
}

.about-page .feature-icon {
    font-size: 1.5rem;
    flex-shrink: 0;
}

.about-page .feature-list strong {
    display: block;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.about-page .feature-list p {
    margin: 0;
    font-size: 0.9rem;
}

.about-page .onion-address {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin: 1rem 0;
}

.about-page .onion-address code {
    padding: 0.5rem 1rem;
    background: var(--bg-tertiary);
    border-radius: 4px;
    font-family: monospace;
    word-break: break-all;
    flex: 1;
    min-width: 200px;
}

.about-page .note {
    font-size: 0.85rem;
    color: var(--text-muted);
    font-style: italic;
}

/* Privacy, Terms Pages */
.privacy-page .privacy-section,
.terms-page .terms-section {
    margin-bottom: 2rem;
}

.privacy-page .data-table,
.terms-page .data-table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
}

.privacy-page .data-table th,
.privacy-page .data-table td,
.terms-page .data-table th,
.terms-page .data-table td {
    padding: 0.75rem;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
}

.privacy-page .data-table th,
.terms-page .data-table th {
    background: var(--bg-tertiary);
    font-weight: 600;
}

/* Contact Page */
.contact-page .contact-methods {
    display: grid;
    gap: 1rem;
    margin-bottom: 2rem;
}

.contact-page .contact-method {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: var(--bg-tertiary);
    border-radius: 8px;
}

.contact-page .contact-icon {
    font-size: 1.5rem;
    flex-shrink: 0;
}

.contact-page .contact-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.contact-page .form-group {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.contact-page .form-group label {
    font-weight: 500;
    color: var(--text-primary);
}

.contact-page .form-group input,
.contact-page .form-group textarea {
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--input-bg);
    color: var(--text-primary);
    font-size: 1rem;
}

.contact-page .form-group input:focus,
.contact-page .form-group textarea:focus {
    outline: none;
    border-color: var(--input-focus);
    box-shadow: 0 0 0 2px rgba(var(--input-focus), 0.2);
}

.contact-page .form-group textarea {
    min-height: 150px;
    resize: vertical;
}

.contact-page .submit-btn {
    padding: 0.75rem 1.5rem;
    background: var(--accent-primary);
    color: var(--bg-primary);
    border: none;
    border-radius: 6px;
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    align-self: flex-start;
    transition: opacity 0.2s;
}

.contact-page .submit-btn:hover {
    opacity: 0.9;
}

/* Help Page */
.help-page .help-section {
    margin-bottom: 2rem;
}

.help-page .keyboard-shortcuts {
    display: grid;
    gap: 0.5rem;
    margin: 1rem 0;
}

.help-page .shortcut-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem;
    background: var(--bg-tertiary);
    border-radius: 4px;
}

.help-page .shortcut-key {
    display: inline-flex;
    gap: 0.25rem;
}

.help-page .shortcut-key kbd {
    padding: 0.25rem 0.5rem;
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    font-family: monospace;
    font-size: 0.85rem;
}

.help-page .bang-examples {
    display: grid;
    gap: 0.5rem;
    margin: 1rem 0;
}

.help-page .bang-example {
    display: flex;
    gap: 1rem;
    padding: 0.5rem;
    background: var(--bg-tertiary);
    border-radius: 4px;
}

.help-page .bang-example code {
    font-family: monospace;
    color: var(--accent-primary);
    white-space: nowrap;
}

/* Responsive */
@media (max-width: 768px) {
    .static-page {
        padding: 1rem;
    }

    .static-page h1 {
        font-size: 1.5rem;
    }

    .page-content {
        padding: 1.5rem;
    }

    .about-page .feature-list li {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }

    .help-page .shortcut-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }
}

/* ============================================================================
   ENHANCED ABOUT PAGE
   ============================================================================ */

.about-header {
    text-align: center;
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.about-header h1 {
    border: none;
    margin-bottom: 0.5rem;
}

.about-header .tagline {
    font-size: 1.1rem;
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

.about-header .version-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: var(--accent-primary);
    color: var(--bg-primary);
    border-radius: 1rem;
    font-size: 0.85rem;
    font-weight: 600;
}

/* Feature Grid */
.feature-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1rem;
}

.feature-card {
    padding: 1.25rem;
    background: var(--bg-tertiary);
    border-radius: 8px;
    border: 1px solid var(--border-color);
}

.feature-card .feature-icon {
    font-size: 1.5rem;
    display: block;
    margin-bottom: 0.5rem;
}

.feature-card h3 {
    font-size: 1rem;
    margin: 0 0 0.5rem 0;
    color: var(--text-primary);
}

.feature-card p {
    margin: 0;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

/* Tor Section */
.tor-section {
    background: var(--bg-tertiary);
    border-radius: 8px;
    padding: 1.5rem;
    border-left: 4px solid #7D4698;
}

.onion-address-box {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin: 1rem 0;
    padding: 0.75rem;
    background: var(--bg-primary);
    border-radius: 6px;
}

.onion-address-box code {
    flex: 1;
    min-width: 200px;
    font-family: var(--font-mono, monospace);
    font-size: 0.85rem;
    word-break: break-all;
    color: var(--accent-primary);
}

.onion-address-box .btn-copy {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.5rem 0.75rem;
    background: var(--accent-primary);
    color: var(--bg-primary);
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.85rem;
}

.onion-address-box .btn-copy:hover {
    opacity: 0.9;
}

.tor-note {
    font-size: 0.85rem;
    color: var(--text-muted);
}

/* API Links */
.api-links, .source-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1rem;
}

.api-link, .source-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    text-decoration: none;
    transition: border-color 0.2s, background-color 0.2s;
}

.api-link:hover, .source-link:hover {
    border-color: var(--accent-primary);
    background: var(--bg-primary);
}

/* Version Grid */
.version-grid {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.5rem 1rem;
    margin: 0;
}

.version-grid dt {
    color: var(--text-muted);
}

.version-grid dd {
    margin: 0;
    color: var(--text-primary);
}

/* ============================================================================
   ENHANCED HELP PAGE
   ============================================================================ */

.help-header {
    text-align: center;
    margin-bottom: 2rem;
}

.help-header h1 {
    border: none;
    margin-bottom: 0.5rem;
}

.help-header .subtitle {
    color: var(--text-secondary);
}

/* Table of Contents */
.help-toc {
    background: var(--bg-tertiary);
    border-radius: 8px;
    padding: 1rem 1.5rem;
    margin-bottom: 2rem;
}

.help-toc h2 {
    font-size: 1rem;
    margin: 0 0 0.75rem 0;
    color: var(--text-muted);
}

.help-toc ul {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.5rem;
    list-style: none;
    padding: 0;
    margin: 0;
}

.help-toc a {
    color: var(--accent-primary);
    text-decoration: none;
}

.help-toc a:hover {
    text-decoration: underline;
}

/* Category Grid */
.category-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 1rem;
}

.category-item {
    padding: 1rem;
    background: var(--bg-tertiary);
    border-radius: 8px;
    text-align: center;
}

.category-item .category-icon {
    font-size: 1.5rem;
    display: block;
    margin-bottom: 0.5rem;
}

.category-item strong {
    display: block;
    color: var(--text-primary);
}

.category-item p {
    margin: 0.25rem 0 0 0;
    font-size: 0.85rem;
    color: var(--text-muted);
}

/* Bang Grid */
.bang-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 0.5rem;
}

.bang-item {
    padding: 0.5rem 0.75rem;
    background: var(--bg-tertiary);
    border-radius: 4px;
    font-size: 0.9rem;
}

.bang-item code {
    color: var(--accent-primary);
    font-weight: 600;
    margin-right: 0.25rem;
}

/* Operator Grid */
.operator-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 0.5rem;
    margin-bottom: 1.5rem;
}

.operator-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.75rem;
    background: var(--bg-tertiary);
    border-radius: 6px;
}

.operator-item code {
    color: var(--accent-primary);
    font-family: var(--font-mono, monospace);
    font-size: 0.9rem;
}

.operator-item span {
    font-size: 0.85rem;
    color: var(--text-muted);
}

/* Example List */
.example-list {
    list-style: none;
    padding: 0;
}

.example-list li {
    padding: 0.5rem 0.75rem;
    background: var(--bg-tertiary);
    border-radius: 4px;
    margin-bottom: 0.5rem;
}

.example-list code {
    color: var(--accent-primary);
}

/* Tables */
.operators-table,
.shortcuts-table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
}

.operators-table th,
.operators-table td,
.shortcuts-table th,
.shortcuts-table td {
    padding: 0.75rem;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
}

.operators-table th,
.shortcuts-table th {
    background: var(--bg-tertiary);
    font-weight: 600;
    color: var(--text-primary);
}

.operators-table code,
.shortcuts-table kbd {
    padding: 0.2rem 0.5rem;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    font-family: var(--font-mono, monospace);
    font-size: 0.85rem;
}

/* API Link Cards */
.api-link-card {
    display: block;
    padding: 1rem 1.25rem;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    text-decoration: none;
    flex: 1;
    min-width: 200px;
}

.api-link-card:hover {
    border-color: var(--accent-primary);
}

.api-link-card h3 {
    margin: 0 0 0.25rem 0;
    color: var(--accent-primary);
    font-size: 1rem;
}

.api-link-card p {
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-muted);
}

/* Privacy List */
.privacy-list {
    list-style: none;
    padding: 0;
}

.privacy-list li {
    padding: 0.75rem;
    background: var(--bg-tertiary);
    border-radius: 6px;
    margin-bottom: 0.5rem;
}

.privacy-list strong {
    color: var(--text-primary);
}

/* FAQ */
.faq-list details {
    margin-bottom: 0.5rem;
    background: var(--bg-tertiary);
    border-radius: 6px;
    overflow: hidden;
}

.faq-list summary {
    padding: 1rem;
    cursor: pointer;
    font-weight: 500;
    color: var(--text-primary);
}

.faq-list summary:hover {
    background: var(--bg-primary);
}

.faq-list details[open] summary {
    border-bottom: 1px solid var(--border-color);
}

.faq-list details p {
    padding: 1rem;
    margin: 0;
}

/* ============================================================================
   HEALTH PAGE
   ============================================================================ */

.health-page {
    max-width: 1000px;
    margin: 0 auto;
    padding: 2rem 1rem;
}

.health-header {
    text-align: center;
    margin-bottom: 2rem;
}

.health-header h1 {
    font-size: 1.75rem;
    margin: 0 0 0.5rem 0;
    color: var(--text-primary);
}

.health-header .tagline {
    font-size: 1rem;
    color: var(--accent-primary);
    margin: 0 0 0.25rem 0;
}

.health-header .description {
    color: var(--text-muted);
    margin: 0;
}

/* Status Banner */
.status-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 1rem;
    border-radius: 8px;
    margin-bottom: 2rem;
    font-weight: 600;
    font-size: 1.1rem;
}

/* Per AI.md PART 13: status-ok/error/warning classes */
.status-banner.status-ok {
    background: rgba(80, 250, 123, 0.15);
    color: var(--accent-success);
}

.status-banner.status-error {
    background: rgba(255, 85, 85, 0.15);
    color: var(--accent-error);
}

.status-banner.status-warning {
    background: rgba(255, 184, 108, 0.15);
    color: var(--accent-warning);
}

/* Health Grid */
.health-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.section-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 1.25rem;
}

.section-card h2 {
    font-size: 1rem;
    margin: 0 0 1rem 0;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Health Info (dl) */
.health-info {
    margin: 0;
}

.info-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border-color);
}

.info-row:last-child {
    border-bottom: none;
}

.info-row dt {
    color: var(--text-muted);
    font-size: 0.9rem;
}

.info-row dd {
    margin: 0;
    color: var(--text-primary);
    font-weight: 500;
}

.info-row code {
    padding: 0.15rem 0.4rem;
    background: var(--bg-tertiary);
    border-radius: 4px;
    font-size: 0.85rem;
    color: var(--accent-primary);
}

/* Badges */
.badge {
    display: inline-block;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    background: var(--bg-tertiary);
    color: var(--text-secondary);
}

.badge-production {
    background: rgba(34, 197, 94, 0.15);
    color: #22c55e;
}

.badge-development {
    background: rgba(234, 179, 8, 0.15);
    color: #eab308;
}

.badge-success {
    background: rgba(34, 197, 94, 0.15);
    color: #22c55e;
}

.badge-error {
    background: rgba(239, 68, 68, 0.15);
    color: #ef4444;
}

.badge-primary {
    background: var(--accent-primary);
    color: var(--bg-primary);
}

/* Component List */
.component-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.component-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 0;
    border-bottom: 1px solid var(--border-color);
}

.component-item:last-child {
    border-bottom: none;
}

.component-icon {
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-size: 0.85rem;
}

.component-ok .component-icon {
    background: rgba(34, 197, 94, 0.15);
    color: #22c55e;
}

.component-error .component-icon {
    background: rgba(239, 68, 68, 0.15);
    color: #ef4444;
}

.component-name {
    flex: 1;
    color: var(--text-primary);
}

.component-status {
    font-size: 0.85rem;
    color: var(--text-muted);
}

/* Feature List in Health */
.section-card .feature-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.section-card .feature-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 0;
    border-bottom: 1px solid var(--border-color);
}

.section-card .feature-item:last-child {
    border-bottom: none;
}

.section-card .feature-icon {
    font-size: 1.1rem;
}

.section-card .feature-name {
    flex: 1;
    color: var(--text-primary);
}

.section-card .feature-status {
    font-size: 0.8rem;
    padding: 0.15rem 0.5rem;
    border-radius: 4px;
}

.section-card .feature-status.status-ok {
    background: rgba(34, 197, 94, 0.15);
    color: #22c55e;
}

.section-card .feature-status.status-warning {
    background: rgba(234, 179, 8, 0.15);
    color: #eab308;
}

.section-card .feature-detail {
    padding: 0.5rem;
    background: var(--bg-tertiary);
    border-radius: 4px;
    margin-bottom: 0.5rem;
}

.section-card .feature-detail code {
    font-size: 0.8rem;
    word-break: break-all;
    color: var(--accent-primary);
}

/* Health Footer */
.health-footer {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
    text-align: center;
    color: var(--text-muted);
    font-size: 0.85rem;
}

.health-footer p {
    margin: 0.25rem 0;
}

.auto-refresh {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.refresh-indicator {
    width: 8px;
    height: 8px;
    background: var(--accent-primary);
    border-radius: 50%;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* Health Page Responsive */
@media (max-width: 768px) {
    .health-grid {
        grid-template-columns: 1fr;
    }

    .status-banner {
        flex-direction: column;
        text-align: center;
    }
}

/* Help Page Responsive */
@media (max-width: 768px) {
    .help-toc ul {
        flex-direction: column;
        gap: 0.5rem;
    }

    .category-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .bang-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .operator-grid {
        grid-template-columns: 1fr;
    }

    .operators-table,
    .shortcuts-table {
        font-size: 0.9rem;
    }

    .operators-table th:nth-child(3),
    .operators-table td:nth-child(3) {
        display: none;
    }
}

/* About Page Responsive */
@media (max-width: 768px) {
    .feature-grid {
        grid-template-columns: 1fr;
    }

    .onion-address-box {
        flex-direction: column;
        align-items: stretch;
    }

    .onion-address-box code {
        min-width: 0;
        text-align: center;
    }

    .api-links {
        flex-direction: column;
    }
}
