:root { 
        /* Ayu Mirage Theme Colors */
        --ayu-bg: #1F2430;
        --ayu-fg: #CCCAC2;
        --ayu-ui: #232834;
        --ayu-ui-border: #191E2A;
        --ayu-selection: #33415E;
        --ayu-comment: #5C6773;
        
        /* Accents */
        --ayu-accent: #FFCC66;
        --ayu-func: #FFD580;
        --ayu-entity: #73D0FF;
        --ayu-string: #D5FF80;
        --ayu-operator: #F29E74;
        --ayu-tag: #5CCFE6;
        --ayu-keyword: #FFA759;
        --ayu-markup: #F28779;
        
        /* Mapping to functional variables */
        --bg-color: var(--ayu-bg);
        --text-color: var(--ayu-fg);
        --card-bg: var(--ayu-ui);
        --card-border: var(--ayu-ui-border);
        --primary-color: var(--ayu-accent);
        --secondary-color: var(--ayu-tag);
        --link-color: var(--ayu-entity);
        --link-hover: var(--ayu-tag);
        
        /* Typography */
        --font-main: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
        --font-mono: 'SF Mono', 'Monaco', 'Inconsolata', 'Fira Code', monospace;
        
        /* Spacing & Radius */
        --radius-sm: 4px;
        --radius-md: 8px;
        --radius-lg: 12px;
        --spacing-unit: 1rem;
         }

*, *::before, *::after { box-sizing: border-box; }

body { display: flex; min-height: 100vh; flex-direction: column; background-color: var(--bg-color); color: var(--text-color); font-family: var(--font-main); font-size: 16px; line-height: 1.6; margin: 0; padding: 0; -webkit-font-smoothing: antialiased; }

main { flex: 1 0 auto; padding: 2rem 0; width: 100%; }

.container { width: 100%; max-width: 800px; margin: 0 auto; padding: 0 1.5rem; }

h1, h2, h3, h4, h5, h6 { color: var(--text-color); margin-top: 2rem; margin-bottom: 1rem; line-height: 1.3; font-weight: 600; }

h1 { font-size: 2.5rem; color: var(--ayu-markup); }

h2 { font-size: 2rem; color: var(--ayu-keyword); }

h3 { font-size: 1.5rem; color: var(--ayu-entity); }

h4 { font-size: 1.25rem; }

p { margin-bottom: 1.5rem; color: var(--text-color); }

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

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

.plotly-embed { width: 100%; margin: 2rem 0; text-align: center; }

.plotly-embed a { display: block; border: 1px solid var(--ayu-ui-background); border-radius: 8px; overflow: hidden; transition: transform 0.2s ease, box-shadow 0.2s ease; }

.plotly-embed a:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.15); text-decoration: none; }

.plotly-embed img { width: 100%; max-width: 100%; height: auto; display: block; }

.plotly-caption { text-align: center; font-style: italic; color: var(--text-muted); margin-top: 0.5rem; font-size: 0.9rem; }

.plotly-figure {
  margin: 2rem 0;
  padding: 1rem;
  border: 1px solid var(--card-border);
  border-radius: var(--radius-md);
  background: var(--card-bg);
}

.plotly-figure .plotly {
  width: 100%;
  min-height: 420px;
}

.plotly-figure figcaption {
  margin-top: 0.75rem;
  color: var(--ayu-comment);
  font-size: 0.9rem;
  font-style: italic;
  text-align: center;
}

nav { background-color: rgba(31, 36, 48, 0.9); border-bottom: 1px solid var(--card-border); padding: 1rem 0; position: sticky; top: 0; z-index: 1000; backdrop-filter: blur(10px); }

nav .nav-wrapper { display: flex; align-items: center; justify-content: space-between; max-width: 800px; margin: 0 auto; padding: 0 1.5rem; }

.brand-logo { display: flex; align-items: center; gap: 10px; font-weight: 700; font-size: 1.2rem; color: var(--ayu-accent) !important; text-decoration: none !important; }

.brand-logo img { width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--ayu-comment); }

nav ul { display: flex; list-style: none; margin: 0; padding: 0; gap: 1.5rem; }

nav ul li a { color: var(--text-color); font-weight: 500; font-size: 0.95rem; padding: 0.5rem; }

nav ul li a:hover { color: var(--ayu-accent); text-decoration: none; }

.btn { display: inline-block; background-color: transparent; color: var(--ayu-accent); border: 1px solid var(--ayu-accent); padding: 0.5rem 1rem; border-radius: var(--radius-sm); font-size: 0.9rem; font-weight: 500; margin-top: 1rem; transition: all 0.2s ease; text-decoration: none !important; }

.btn:hover { background-color: var(--ayu-accent); color: var(--bg-color); }

.blog-post { background-color: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--radius-md); padding: 2rem; margin-bottom: 2rem; transition: transform 0.2s ease, border-color 0.2s ease; }

.blog-post:hover { border-color: var(--ayu-comment); transform: translateY(-2px); }

.blog-post-card { background-color: var(--ayu-ui); border: 1px solid var(--ayu-ui-border); border-radius: 8px; padding: 1.5rem; margin-bottom: 2rem; transition: transform 0.2s ease, border-color 0.2s ease; display: flex; flex-direction: row; justify-content: space-between; align-items: flex-start; gap: 1.5rem; }

.blog-post-card:hover { transform: translateY(-2px); border-color: var(--ayu-accent); }

.blog-post-content { flex: 1; }

.blog-post-card h4 { margin-top: 0; margin-bottom: 0.5rem; font-size: 1.5rem; color: var(--ayu-accent); }

.blog-post-card p { margin-bottom: 1.5rem; color: var(--ayu-fg); line-height: 1.6; }

.blog-post-image-container { flex: 0 0 200px; height: 150px; overflow: hidden; border-radius: 4px; }

.blog-post-image { width: 100%; height: 100%; object-fit: cover; }

.blog-article img { max-width: 100%; height: auto; border-radius: var(--radius-sm); margin: 1.5rem 0; }

@media (max-width: 768px) {
.blog-post { flex-direction: column-reverse; gap: 1rem; }

.blog-post-card { flex-direction: column-reverse; }

.blog-post-image-container { flex: none; width: 100%; height: 200px; margin-bottom: 1rem; }
}

.page-footer { margin-top: 4rem; padding: 2rem 0; border-top: 1px solid var(--card-border); text-align: center; color: var(--ayu-comment); font-size: 0.9rem; }

.footer-copyright { margin-top: 1rem; }

pre { background-color: #191E2A; border: 1px solid var(--card-border); border-radius: var(--radius-sm); padding: 1rem; overflow-x: auto; font-family: var(--font-mono); font-size: 0.9rem; }

code { font-family: var(--font-mono); background-color: rgba(255, 255, 255, 0.05); padding: 0.2rem 0.4rem; border-radius: 3px; font-size: 0.85em; color: var(--ayu-string); }

pre code { background: none; padding: 0; color: inherit; }

.codehilite:has(code.language-markdown), pre:has(code.language-markdown) { margin-top: 1rem; padding: 1rem; background: rgba(115, 208, 255, 0.1); border-left: 3px solid var(--ayu-tag); border-radius: 4px; border: 1px solid var(--card-border); }

.codehilite:has(code.language-markdown) pre, pre:has(code.language-markdown) { background: #2a2f3a; padding: 1rem; border-radius: 4px; font-size: 0.85em; white-space: pre-wrap; word-wrap: break-word; overflow-wrap: break-word; border: 1px solid #3e4451; margin: 0; }

code.language-markdown { white-space: pre-wrap; word-wrap: break-word; overflow-wrap: break-word; }

.blog-article table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: 0.9rem; overflow-x: auto; display: block; }

.blog-article thead { border-bottom: 2px solid var(--ayu-comment); }

.blog-article th { padding: 0.6rem 1rem; text-align: left; color: var(--ayu-accent); font-weight: 600; white-space: nowrap; }

.blog-article td { padding: 0.6rem 1rem; border-bottom: 1px solid var(--card-border); color: var(--ayu-fg); }

.blog-article tr:hover { background: rgba(255, 255, 255, 0.03); }

.blog-article td strong { color: var(--ayu-entity); }

blockquote { margin: 1.5rem 0; padding: 1rem 1.5rem; background: rgba(115, 208, 255, 0.1); border-left: 3px solid var(--ayu-tag); border-radius: 4px; color: var(--ayu-fg); }

blockquote p { margin: 0.5rem 0; }

blockquote p:first-child { margin-top: 0; }

blockquote p:last-child { margin-bottom: 0; }

blockquote ul, blockquote ol { margin: 0.5rem 0; padding-left: 1.5rem; }

blockquote li { margin: 0.25rem 0; }

.hero-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 2rem; margin-bottom: 2rem; }

.hero-card, .contact-card, .skills-card, .experience-card { background-color: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--radius-md); padding: 1.5rem; height: 100%; }

.hero-name { font-size: 2.5rem; font-weight: 700; color: var(--ayu-markup); margin-bottom: 0.5rem; }

.hero-title { font-size: 1.2rem; color: var(--ayu-keyword); margin-bottom: 1.5rem; }

.contact-item { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.75rem; }

.contact-item .material-icons { color: var(--ayu-tag); }

.skills-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1rem; }

.section-icon { color: var(--ayu-operator); vertical-align: middle; margin-right: 0.5rem; }

.resume-container { max-width: 900px; margin: 0 auto; padding: 0.5rem 1rem 2rem 1rem; color: var(--ayu-fg); }

.resume-header { margin-bottom: 2rem; border-bottom: 1px solid var(--ayu-ui-border); padding-bottom: 1.5rem; }

.header-pdf-link { font-size: 0.9rem; color: var(--ayu-entity); text-decoration: none; font-weight: 500; }

.header-pdf-link:hover { text-decoration: underline; color: var(--ayu-accent); }

.resume-name-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }

.pdf-download-btn { display: inline-flex; align-items: center; gap: 4px; padding: 6px 14px; font-size: 0.85rem; font-weight: 500; color: var(--ayu-bg); background-color: var(--ayu-accent); border-radius: var(--radius-sm); text-decoration: none; white-space: nowrap; transition: background-color 0.2s ease, transform 0.1s ease; }

.pdf-download-btn:hover { background-color: var(--ayu-func); transform: translateY(-1px); text-decoration: none; color: var(--ayu-bg); }

.resume-name { font-size: 2.5rem; font-weight: 700; margin-bottom: 0.5rem; color: var(--ayu-accent); line-height: 1.2; }

.resume-title { font-size: 1.2rem; color: var(--ayu-tag); margin-bottom: 0.75rem; font-weight: 500; }

.resume-contact { display: flex; flex-wrap: wrap; gap: 0.5rem; font-size: 0.95rem; color: var(--ayu-comment); }

.resume-contact a { color: var(--ayu-entity); text-decoration: none; }

.resume-contact a:hover { text-decoration: underline; }

.dense-section { margin-bottom: 2rem; border-bottom: 1px solid var(--ayu-ui-border); padding-bottom: 2rem; }

.dense-section:last-child { border-bottom: none; }

.dense-section h2 { font-size: 1.5rem; margin-bottom: 1rem; color: var(--ayu-accent); text-transform: uppercase; letter-spacing: 0.05em; }

.skill-row { margin-bottom: 0.5rem; line-height: 1.5; }

.skill-label { font-weight: 700; color: var(--ayu-tag); }

.experience-item, .education-item { margin-bottom: 1.5rem; }

.job-header { display: flex; flex-wrap: wrap; align-items: baseline; gap: 0.5rem; margin-bottom: 0.25rem; }

.job-role { font-size: 1.1rem; font-weight: 700; color: var(--ayu-fg); margin: 0; }

.job-company { font-size: 1.1rem; color: var(--ayu-entity); font-weight: 500; }

.job-company::before { content: "@"; margin-right: 0.25rem; color: var(--ayu-comment); }

.job-date { margin-left: auto; font-size: 0.9rem; color: var(--ayu-comment); font-family: var(--font-mono); }

.experience-item ul { margin-top: 0.5rem; padding-left: 1.2rem; margin-bottom: 0; }

.experience-item li { margin-bottom: 0.25rem; line-height: 1.5; color: var(--ayu-fg); }

.project-highlight { margin-top: 0.75rem; padding-left: 0.5rem; border-left: 2px solid var(--ayu-ui-border); }

.project-label { font-weight: 700; color: var(--ayu-tag); }

@media (max-width: 768px) {
.hero-grid { grid-template-columns: 1fr; }

h1 { font-size: 2rem; }
}

@media (max-width: 600px) {
.job-header { flex-direction: column; gap: 0.25rem; }

.job-date { margin-left: 0; }

.resume-name { font-size: 2rem; }
}

.experiment-card { border: 1px solid var(--ayu-ui-border); background: var(--ayu-ui); padding: 1.5rem; border-radius: var(--radius-md); margin-bottom: 1.5rem; }

.experiment-card h2 { margin-top: 0; color: var(--ayu-accent); }

.form-group { margin-bottom: 1.5rem; }

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

.form-group input[type='text'], .form-group input[type='file'] { width: 100%; padding: 0.75rem; border: 2px solid var(--ayu-ui-border); border-radius: var(--radius-sm); background: var(--ayu-ui); color: var(--ayu-fg); font-family: var(--font-main); box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.2); }

.form-group input[type='text']:focus, .form-group input[type='file']:focus { outline: none; border-color: var(--ayu-accent); box-shadow: 0 0 0 3px rgba(255, 204, 102, 0.1), inset 0 1px 3px rgba(0, 0, 0, 0.2); }

.form-group input[type='text']::placeholder { color: var(--ayu-comment); opacity: 0.7; }

.help-text { font-size: 0.875rem; color: var(--ayu-accent); margin-top: 0.25rem; }

.info { font-size: 0.875rem; color: var(--ayu-comment); margin-top: 1rem; }

.progress-bar { width: 100%; height: 20px; background: var(--ayu-ui); border-radius: var(--radius-lg); overflow: hidden; margin: 1rem 0; border: 1px solid var(--ayu-ui-border); }

.progress-fill { height: 100%; background: linear-gradient(90deg, var(--ayu-accent) 0%, var(--ayu-tag) 100%); transition: width 0.3s ease; }

.log { background: var(--ayu-bg); padding: 1rem; border-radius: var(--radius-sm); border: 1px solid var(--ayu-ui-border); font-family: var(--font-mono); font-size: 0.875rem; min-height: 800px; max-height: 1200px; overflow-y: auto; list-style: none; margin: 0; }

.log li { padding: 0.25rem 0; color: var(--ayu-fg); white-space: pre-wrap; word-wrap: break-word; overflow-wrap: break-word; }

.success-header { color: var(--ayu-string); }

.error-header { color: var(--ayu-markup); }

.action-buttons { display: flex; gap: 1rem; margin-top: 1.5rem; flex-wrap: wrap; }

.btn-primary { background: var(--ayu-accent); color: var(--ayu-bg); padding: 0.75rem 1.5rem; border: none; border-radius: var(--radius-sm); font-weight: 500; cursor: pointer; text-decoration: none; display: inline-block; }

.btn-primary:hover { background: var(--ayu-func); }

.btn-secondary { background: transparent; color: var(--ayu-tag); padding: 0.75rem 1.5rem; border: 1px solid var(--ayu-tag); border-radius: var(--radius-sm); font-weight: 500; cursor: pointer; text-decoration: none; display: inline-block; }

.btn-secondary:hover { background: var(--ayu-tag); color: var(--ayu-bg); }

.btn-tertiary { background: transparent; color: var(--ayu-comment); padding: 0.75rem 1.5rem; border: 1px solid var(--ayu-ui-border); border-radius: var(--radius-sm); cursor: pointer; text-decoration: none; display: inline-block; }

.btn-tertiary:hover { border-color: var(--ayu-comment); color: var(--ayu-fg); }

.report-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 2rem; padding-bottom: 1rem; border-bottom: 1px solid var(--ayu-ui-border); }

.back-link { color: var(--ayu-entity); text-decoration: none; }

.back-link:hover { color: var(--ayu-tag); }

.btn-download { background: var(--ayu-tag); color: var(--ayu-bg); padding: 0.5rem 1rem; border-radius: var(--radius-sm); text-decoration: none; font-size: 0.875rem; }

.btn-download:hover { background: var(--ayu-entity); }

.report-content { line-height: 1.6; }

.report-content h1, .report-content h2, .report-content h3 { margin-top: 2rem; margin-bottom: 1rem; color: var(--ayu-fg); }

.report-content h1 { font-size: 2rem; color: var(--ayu-accent); margin-top: 0; }

.report-content h2 { font-size: 1.5rem; color: var(--ayu-entity); border-bottom: 1px solid var(--ayu-ui-border); padding-bottom: 0.5rem; }

.report-content h3 { font-size: 1.25rem; color: var(--ayu-tag); }

.report-content p { margin-bottom: 1rem; }

.report-content table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; background: var(--ayu-ui); border: 1px solid var(--ayu-ui-border); }

.report-content table th { background: var(--ayu-bg); color: var(--ayu-accent); font-weight: 600; text-align: left; padding: 0.75rem 1rem; border: 1px solid var(--ayu-ui-border); }

.report-content table td { padding: 0.75rem 1rem; border: 1px solid var(--ayu-ui-border); color: var(--ayu-fg); }

.report-content table tr:nth-child(even) { background: rgba(255, 255, 255, 0.02); }

.report-content table tr:hover { background: rgba(255, 255, 255, 0.05); }

.report-content code { font-family: var(--font-mono); background: rgba(255, 255, 255, 0.05); padding: 0.2rem 0.4rem; border-radius: 3px; font-size: 0.9em; color: var(--ayu-string); }

.report-content pre { background: var(--ayu-bg); border: 1px solid var(--ayu-ui-border); border-radius: var(--radius-sm); padding: 1rem; overflow-x: auto; margin: 1rem 0; }

.report-content pre code { background: none; padding: 0; }

.keyboard-widget { margin: 2rem 0; }

.layer-tabs { display: flex; justify-content: center; gap: 8px; margin-bottom: 25px; flex-wrap: wrap; }

.layer-tabs .tab { padding: 10px 20px; background: var(--ayu-ui); border: 1px solid var(--ayu-ui-border); border-radius: 6px; cursor: pointer; transition: all 0.2s; font-size: 0.85rem; font-weight: 500; color: var(--ayu-fg); }

.layer-tabs .tab:hover { background: var(--ayu-selection); border-color: var(--ayu-comment); }

.layer-tabs .tab.active { background: var(--ayu-accent); border-color: var(--ayu-accent); color: var(--ayu-bg); }

.keyboard-container { margin: 0 auto 30px; position: relative; }

.keyboard-container .key { width: 60px; height: 60px; background: linear-gradient(145deg, var(--ayu-selection), var(--ayu-ui)); border: 1px solid var(--ayu-ui-border); border-radius: 6px; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: 0.7rem; position: absolute; transition: all 0.15s; box-sizing: border-box; }

.keyboard-container .key:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.3); border-color: var(--ayu-accent); }

.keyboard-container .key .main { font-weight: 600; color: var(--ayu-fg); font-size: 0.8rem; text-align: center; line-height: 1.1; }

.keyboard-container .key .hold { font-size: 0.6rem; color: var(--ayu-accent); margin-top: 2px; text-align: center; }

.keyboard-container .key .tap { font-size: 0.6rem; color: var(--ayu-string); text-align: center; }

.keyboard-container .key.mod { background: linear-gradient(145deg, #1a3a5c, var(--ayu-ui)); border-color: var(--ayu-entity); }

.keyboard-container .key.mod .main { color: var(--ayu-entity); }

.keyboard-container .key.layer-key { background: linear-gradient(145deg, #4a1942, #3d1536); border-color: #6b2d5c; }

.keyboard-container .key.layer-key .main { color: var(--ayu-markup); }

.keyboard-container .key.special { background: linear-gradient(145deg, #2d4a2d, #1f3a1f); border-color: #3d5c3d; }

.keyboard-container .key.special .main { color: var(--ayu-string); }

.keyboard-container .key.transparent { opacity: 0.3; background: linear-gradient(145deg, var(--ayu-bg), #151525); }

.keyboard-container .key.thumb { background: linear-gradient(145deg, var(--ayu-ui-border), var(--ayu-ui)); }

.keyboard-widget .notes { max-width: 900px; margin: 30px auto 0; padding: 20px; background: var(--ayu-ui); border-radius: 8px; border: 1px solid var(--ayu-ui-border); }

.keyboard-widget .notes h3 { color: var(--ayu-accent); margin-bottom: 12px; font-size: 1rem; font-weight: 500; margin-top: 0; }

.keyboard-widget .notes ul { list-style: none; display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 8px; padding: 0; margin: 0; }

.keyboard-widget .notes li { font-size: 0.8rem; color: var(--ayu-comment); padding: 4px 0; }

.keyboard-widget .notes li strong { color: var(--ayu-string); }

.keyboard-widget .notes .behavior-note { margin-top: 15px; padding-top: 15px; border-top: 1px solid var(--ayu-ui-border); font-size: 0.8rem; color: var(--ayu-comment); }

.keyboard-widget .notes .behavior-label { color: var(--ayu-accent); font-weight: 500; }

.keyboard-widget .legend { display: flex; justify-content: center; gap: 25px; margin-top: 20px; flex-wrap: wrap; }

.keyboard-widget .legend-item { display: flex; align-items: center; gap: 8px; font-size: 0.8rem; color: var(--ayu-comment); }

.keyboard-widget .legend-color { width: 16px; height: 16px; border-radius: 3px; }

.keyboard-widget .legend-color.normal { background: var(--ayu-selection); border: 1px solid var(--ayu-ui-border); }

.keyboard-widget .legend-color.mod { background: #1a3a5c; border: 1px solid var(--ayu-entity); }

.keyboard-widget .legend-color.layer { background: #4a1942; border: 1px solid #6b2d5c; }

.keyboard-widget .legend-color.special { background: #2d4a2d; border: 1px solid #3d5c3d; }

.keyboard-error { padding: 2rem; text-align: center; color: var(--ayu-markup); background: var(--ayu-ui); border-radius: var(--radius-md); border: 1px solid var(--ayu-markup); }

@media (max-width: 900px) {
.keyboard-container { transform: scale(0.7); transform-origin: top center; }

.layer-tabs .tab { padding: 8px 14px; font-size: 0.75rem; }
}

/* --- Additional mobile responsive --- */
@media (max-width: 768px) {
    /* Scrollable tables */
    .table-wrapper {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        margin-bottom: 1.5rem;
    }
    .table-wrapper table { margin-bottom: 0; }

    /* Blog cards */
    .blog-post-card { flex-direction: column; }
    .blog-post-image-container { width: 100%; }

    /* Resume */
    .resume-header .resume-name-row { flex-direction: column; gap: 0.5rem; }
    .resume-contact { flex-wrap: wrap; }
    .job-header { flex-direction: column; gap: 0.25rem; }

    /* Plotly figures */
    .figure-container { padding: 0.75rem; margin: 1rem 0; overflow: visible; }
    .figure-container .modebar { opacity: 0; transition: opacity 0.2s; }
    .figure-container:active .modebar,
    .figure-container:hover .modebar { opacity: 1; }
    .plotly-figure { padding: 0.75rem; margin: 1rem 0; }
    .plotly-figure .plotly { min-height: 320px; }
    .plotly-figure .modebar { opacity: 0; transition: opacity 0.2s; }
    .plotly-figure:active .modebar,
    .plotly-figure:hover .modebar { opacity: 1; }
}

/* Code language labels */
.codehilite { position: relative; }
.codehilite[data-lang]::after {
    content: attr(data-lang);
    position: absolute;
    top: 0.4rem;
    right: 0.5rem;
    font-size: 0.7rem;
    color: var(--ayu-comment);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    opacity: 0.6;
    pointer-events: none;
}
