.desktop-shell {
    min-height: 100vh;
    position: relative;
}

.eyebrow {
    margin: 0 0 6px;
    font-size: 0.74rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    opacity: 0.75;
}

.hero-widget h1,
.hero-panel h2 {
    margin: 0;
    font-size: clamp(1.5rem, 2vw, 2.2rem);
    line-height: 1.05;
}

.hero-role,
.hero-subrole,
.hero-summary,
.meta-line {
    margin: 6px 0 0;
    color: inherit;
    opacity: 0.92;
}

.headline {
    font-size: 1.02rem;
    line-height: 1.7;
}

.metric-label {
    display: inline-block;
    margin-bottom: 8px;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted-ink);
}

.metric-stack strong {
    display: block;
    margin-bottom: 10px;
    font-size: 1.26rem;
}

.metric-stack p {
    margin: 0;
    line-height: 1.7;
}

.icon-badge,
.mini-badge,
.app-icon {
    position: relative;
    overflow: hidden;
    display: inline-grid;
    place-items: center;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0.6));
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12);
}

.icon-badge::before,
.mini-badge::before,
.app-icon::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    background: linear-gradient(135deg, var(--icon-start, #2563eb), var(--icon-end, #38bdf8));
    opacity: 0.85;
    z-index: 0;
}

.icon-badge > *,
.mini-badge > *,
.app-icon > * {
    position: relative;
    z-index: 1;
}

.icon-badge {
    width: var(--desktop-icon-size);
    height: var(--desktop-icon-size);
    border-radius: calc(var(--desktop-icon-size) * 0.25);
}

.mini-badge {
    width: 28px;
    height: 28px;
    border-radius: 7px;
    font-size: 0.65rem;
    flex: 0 0 auto;
}

.app-icon {
    width: 54px;
    height: 54px;
    border-radius: 12px;
    flex: 0 0 auto;
}

.app-icon--sm {
    width: 38px;
    height: 38px;
    border-radius: 8px;
}

.app-icon--lg {
    width: 62px;
    height: 62px;
    border-radius: 14px;
}

.icon-badge svg,
.mini-badge svg,
.app-icon svg {
    width: 28px;
    height: 28px;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.icon-badge i,
.mini-badge i,
.app-icon i {
    font-size: 1.2rem;
    line-height: 1;
}

.app-icon--sm svg {
    width: 20px;
    height: 20px;
}

.app-icon--sm i {
    font-size: 0.95rem;
}

.icon-badge svg {
    width: calc(var(--desktop-icon-size) * 0.52);
    height: calc(var(--desktop-icon-size) * 0.52);
}

.icon-badge i {
    font-size: calc(var(--desktop-icon-size) * 0.34);
}

.badge-blue,
.app-sky { --icon-start: #0077ff; --icon-end: #5eb3ff; }
.badge-cyan,
.app-cyan { --icon-start: #008fb3; --icon-end: #20b2d8; }
.badge-orange,
.app-orange { --icon-start: #d97706; --icon-end: #f59e0b; }
.badge-violet,
.app-violet { --icon-start: #6d28d9; --icon-end: #8b5cf6; }
.badge-emerald,
.app-emerald { --icon-start: #047857; --icon-end: #10b981; }
.badge-slate,
.app-slate { --icon-start: #4b5563; --icon-end: #6b7280; }
.badge-rose,
.app-rose { --icon-start: #be123c; --icon-end: #e11d48; }
.badge-gold,
.app-gold { --icon-start: #b45309; --icon-end: #d97706; }
.badge-lime,
.app-lime { --icon-start: #4d7c0f; --icon-end: #65a30d; }
.badge-linkedin,
.app-linkedin { --icon-start: #0077b5; --icon-end: #0a8cc8; }

.section-title,
.card-heading,
.timeline-top,
.game-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

.section-title {
    margin-bottom: 14px;
    font-size: 0.88rem;
    font-weight: 700;
}

.widget-actions,
.action-row,
.inline-actions,
.game-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.primary-button,
.secondary-button,
.toolbar button,
.game-actions button,
.inline-actions button,
.upload-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 16px;
    border-radius: 14px;
    border: 1px solid transparent;
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.primary-button {
    background: linear-gradient(135deg, rgba(var(--accent-rgb), 1), rgba(var(--accent-rgb), 0.7));
    color: #ffffff;
}

.secondary-button,
.toolbar button,
.game-actions button,
.inline-actions button,
.upload-button,
.tab-button {
    background: rgba(255, 255, 255, 0.74);
    color: var(--ink);
    border-color: rgba(15, 23, 42, 0.08);
}

.primary-button:hover,
.secondary-button:hover,
.toolbar button:hover,
.game-actions button:hover,
.inline-actions button:hover,
.upload-button:hover,
.desktop-shortcut:hover,
.taskbar-app:hover,
.taskbar-core:hover,
.start-app:hover,
.recommended-item:hover,
.contact-card:hover,
.swatch:hover {
    transform: translateY(-1px);
}

.chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.chip,
.pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.chip {
    padding: 8px 12px;
    color: var(--ink);
    background: rgba(var(--accent-rgb), 0.12);
    border: 1px solid rgba(var(--accent-rgb), 0.18);
}

.pill {
    padding: 6px 10px;
    background: rgba(var(--accent-rgb), 0.14);
    color: rgba(var(--accent-rgb), 1);
}

.pill.subtle {
    background: rgba(15, 23, 42, 0.08);
    color: var(--muted-ink);
}

.secondary-button.is-active {
    background: rgba(var(--accent-rgb), 0.12);
    border-color: rgba(var(--accent-rgb), 0.24);
    color: rgba(var(--accent-rgb), 1);
}

.availability-stack {
    display: grid;
    gap: 10px;
}

.availability-stack p {
    margin: 0;
}

.availability-pill {
    justify-self: start;
}

.availability-pill.is-available {
    background: rgba(16, 185, 129, 0.14);
    color: #047857;
    border: 1px solid rgba(16, 185, 129, 0.18);
}

.availability-pill.is-paused {
    background: rgba(245, 158, 11, 0.14);
    color: #b45309;
    border: 1px solid rgba(245, 158, 11, 0.18);
}

.mono {
    font-family: var(--mono-font);
}

.muted-copy,
.stack-list span,
.feature-list li,
.contact-card span,
.recommended-item span:last-child {
    color: var(--muted-ink);
}

.content-card,
.project-card,
.contact-card,
.recommended-item,
.start-app,
.taskbar,
.start-menu,
.taskbar-app,
.swatch,
.hero-sidecard {
    border: 1px solid var(--line);
}

.hero-sidecard,
.content-card,
.project-card,
.contact-card {
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 10px 28px rgba(148, 163, 184, 0.14);
}

.hero-copy,
.hero-sidecard,
.content-card,
.project-card,
.contact-card {
    padding: 20px;
}
